1.C++ 包含对二类时间操作的支持
chrono库,以各种精度跟踪时间的类型的灵活汇集(如std::chrono::time_point )。
C 风格日期和时间工具(如 std::time )。
2.分类
时钟
时间点
时长
当天时刻
日历
时区
C风格日期与时间库:如std::time_t,std::difftime和CLOCKS_PER_SEC.
3.样例-测试一个函数执行了多久
#include <iostream>
#include <chrono>
long fibonacci(unsigned n)
{
if (n < 2) return n;
return fibonacci(n-1) + fibonacci(n-2);
}
int main()
{
auto start = std::chrono::steady_clock::now();
std::cout << "f(42) = " << fibonacci(42) << '\n';
auto end = std::chrono::steady_clock::now();
std::chrono::duration<double> elapsed_seconds = std::chrono::duration<double>(end-start);
std::cout << "elapsed time: " << elapsed_seconds.count() << "s\n";
}
4.时长-std::chrono::duration
时长由时间跨度组成,定义为某时间单位的某个计次数.
例如,"42秒"可表示为由42个1秒时间点位的计次所组成的时长.
// g++ 003.cpp -std=c++11
// 003.cpp
#include <iostream>
#include <chrono>
#include <thread>
using namespace std;
int main()
{
cout<<"main thread will sleep 3 seconds."<<endl;
std::this_thread::sleep_for(std::chrono::milliseconds(3000));
cout<<"main thread 3 seconds later"<<endl;
}