C++11 std::chrono庫詳解

複製代碼ios

2.Time points std::chrono::time_point 表示一個具體時間,如上個世紀80年代、你的生日、今天下午、火車出發時間等,只要它能用計算機時鐘表示。鑑於咱們使用時間的情景不一樣,這個time point具體到什麼程度,由選用的單位決定。一個time point必須有一個clock計時。參見clock的說明。算法

1 template <class Clock, class Duration = typename Clock::duration> class time_point;函數

下面是構造使用time_point的例子: 複製代碼工具

1 // time_point constructors 2 #include <iostream> 3 #include <chrono> 4 #include <ctime> 5
6 int main () 7 { 8 using namespace std::chrono; 9
10 system_clock::time_point tp_epoch; // epoch value 11
12 time_point <system_clock,duration<int>> tp_seconds (duration<int>(1)); 13
14 system_clock::time_point tp (tp_seconds); 15
16 std::cout << "1 second since system_clock epoch = "; 17 std::cout << tp.time_since_epoch().count(); 18 std::cout << " system_clock periods." << std::endl; 19
20 // display time_point: 21 std::time_t tt = system_clock::to_time_t(tp); 22 std::cout << "time_point tp is: " << ctime(&tt); 23
24 return 0; 25 } 26spa

複製代碼code

time_point有一個函數time_from_eproch()用來得到1970年1月1日到time_point時間通過的duration。 舉個例子,若是timepoint以天爲單位,函數返回的duration就以天爲單位。進程

因爲各類time_point表示方式不一樣,chrono也提供了相應的轉換函數 time_point_cast。get

1 template <class ToDuration, class Clock, class Duration> 2 time_point<Clock,ToDuration> time_point_cast (const time_point<Clock,Duration>& tp);string

好比計算 / 複製代碼io

1 / time_point_cast 2 #include <iostream> 3 #include <ratio> 4 #include <chrono> 5
6 int main () 7 { 8 using namespace std::chrono; 9
10 typedef duration<int,std::ratio<606024>> days_type; 11
12 time_point<system_clock,days_type> today = time_point_cast<days_type>(system_clock::now()); 13
14 std::cout << today.time_since_epoch().count() << " days since epoch" << std::endl; 15
16 return 0; 17 }

複製代碼

3.Clocks

std::chrono::system_clock 它表示當前的系統時鐘,系統中運行的全部進程使用now()獲得的時間是一致的。 每個clock類中都有肯定的time_point, duration, Rep, Period類型。 操做有: now() 當前時間time_point to_time_t() time_point轉換成time_t秒 from_time_t() 從time_t轉換成time_point 典型的應用是計算時間日期:

複製代碼

1 // system_clock example 2 #include <iostream> 3 #include <ctime> 4 #include <ratio> 5 #include <chrono> 6
7 int main () 8 { 9 using std::chrono::system_clock; 10
11 std::chrono::duration<int,std::ratio<606024> > one_day (1); 12
13 system_clock::time_point today = system_clock::now(); 14 system_clock::time_point tomorrow = today + one_day; 15
16 std::time_t tt; 17
18 tt = system_clock::to_time_t ( today ); 19 std::cout << "today is: " << ctime(&tt); 20
21 tt = system_clock::to_time_t ( tomorrow ); 22 std::cout << "tomorrow will be: " << ctime(&tt); 23
24 return 0; 25 } 26

複製代碼

std::chrono::steady_clock 爲了表示穩定的時間間隔,後一次調用now()獲得的時間老是比前一次的值大(這句話的意思實際上是,若是中途修改了系統時間,也不影響now()的結果),每次tick都保證過了穩定的時間間隔。 操做有: now() 獲取當前時鐘 典型的應用是給算法計時: 複製代碼

1 // steady_clock example 2 #include <iostream> 3 #include <ctime> 4 #include <ratio> 5 #include <chrono> 6
7 int main () 8 { 9 using namespace std::chrono; 10
11 steady_clock::time_point t1 = steady_clock::now(); 12
13 std::cout << "printing out 1000 stars...\n"; 14 for (int i=0; i<1000; ++i) std::cout << "*"; 15 std::cout << std::endl; 16
17 steady_clock::time_point t2 = steady_clock::now(); 18
19 duration<double> time_span = duration_cast<duration<double>>(t2 - t1); 20
21 std::cout << "It took me " << time_span.count() << " seconds."; 22 std::cout << std::endl; 23
24 return 0; 25 } 26

複製代碼

最後一個時鐘,std::chrono::high_resolution_clock 顧名思義,這是系統可用的最高精度的時鐘。實際上high_resolution_clock只不過是system_clock或者steady_clock的typedef。 操做有: now() 獲取當前時鐘。 chrono庫還有幾個小特性,可是像這種工具庫,本着夠用則已的態度,就不求全責備了。


下面咱們再來對比同樣,跨平臺獲取系統時間的不一樣的方法:

1、傳統的獲取系統時間的方法

傳統的C++獲取時間的方法須要分平臺來定義。相信百度代碼也很多。

我本身寫了下,以下。

const std::string getCurrentSystemTime() {

if (PLATFORM_ANDROID || PLATFORM_IOS)
{
	struct timeval s_now;
	struct tm* p_tm;
	gettimeofday(&s_now,NULL);
	p_tm = localtime((const time_t*)&s_now.tv_sec);
	char date[60] = {0};
	sprintf(date, "%d-%02d-%02d      %02d:%02d:%02d",
		(int)p_tm->tm_year + 1900,(int)p_tm->tm_mon + 1,(int)p_tm->tm_mday,
		(int)p_tm->tm_hour,(int)p_tm->tm_min,(int)p_tm->tm_sec);
	return std::string(date);
}
if (PLATFORM_W32)
{
	struct tm* p_tm;
	time_t timep;
	time(&timep);
	p_tm = localtime(&timep);
	char date[60] = {0};
	sprintf(date, "%d-%02d-%02d      %02d:%02d:%02d",
		(int)p_tm->tm_year + 1900,(int)p_tm->tm_mon + 1,(int)p_tm->tm_mday,
		(int)p_tm->tm_hour,(int)p_tm->tm_min,(int)p_tm->tm_sec);
	log("%s",date);
	return std::string(date);
}
return "";

}

2、C++11 std標準庫跨平臺方法

顯然,咱們注意到不一樣平臺下的代碼類似度很高,那麼能不能利用C++11裏面的新特性,使得兩者合併呢?

答案是確定的。

很簡單的,代碼以下:

const std::string getCurrentSystemTime() { auto tt = std::chrono::system_clock::to_time_t (std::chrono::system_clock::now()); struct tm* ptm = localtime(&tt); char date[60] = {0}; sprintf(date, "%d-%02d-%02d %02d:%02d:%02d", (int)ptm->tm_year + 1900,(int)ptm->tm_mon + 1,(int)ptm->tm_mday, (int)ptm->tm_hour,(int)ptm->tm_min,(int)ptm->tm_sec); return std::string(date); }

又短又簡單有木有。

相關文章
相關標籤/搜索