samedi 3 mars 2018

How to convert std::chrono::high_resolution_clock::now() to milliseconds, microseconds, ...?

I got this code from How to get duration, as int milli's and float seconds from <chrono>?

#include <chrono>
#include <iostream>

int main (int argc, char *argv[])
{
  auto t0 = std::chrono::high_resolution_clock::now();
  auto t1 = std::chrono::high_resolution_clock::now();

  std::chrono::duration< double > fs = t1 - t0;
  std::chrono::milliseconds d = std::chrono::duration_cast< std::chrono::milliseconds >( fs );

  std::cout << fs.count() << "s\n";
  std::cout << d.count() << "ms\n";
}

Which works perfectly, but how I can create a time stamp with:

hour:minute:second:millisecond:microsecond:nanosecond

Using the auto t0 = std::chrono::high_resolution_clock::now() value?

I tried to print the auto t0 = std::chrono::high_resolution_clock::now(); value, to see what is has inside, however it only gave me a big error stack:

#include <chrono>
#include <iostream>

int main (int argc, char *argv[])
{
  auto t0 = std::chrono::high_resolution_clock::now();
  std::cout << t0 << "\n";
}

Error:

main2.cpp: In function 'int main(int, char**)':
main2.cpp:10:13: error: no match for 'operator<<' (operand types are 'std::ostream {aka std::basic_ostream<char>}' and 'std::chrono::time_point<std::chrono::_V2::system_clock, std::chrono::duration<long long int, std::ratio<1, 1000000000> > >')
   std::cout << t0 << "\n";
   ~~~~~~~~~~^~~~~

Aucun commentaire:

Enregistrer un commentaire