2011-05-16 83 views
46

如何在C++中獲得uint unix時間戳?我搜索了一下,似乎大多數方法都在尋找更復雜的方法來表示時間。我能不能把它作爲uint使用C++獲取Unix時間戳

回答

50

time()是最簡單的功能 - 自Epoch以來的秒數。 Linux手冊頁here

以上鍊接的頁面cppreference給出了這樣的example

#include <ctime> 
#include <iostream> 

int main() 
{ 
    std::time_t result = std::time(nullptr); 
    std::cout << std::asctime(std::localtime(&result)) 
       << result << " seconds since the Epoch\n"; 
} 
+3

「Epoch」當然是Unix和Linux上的Unix版本,但這不是通用的。 – MSalters 2011-05-17 08:09:09

31
#include<iostream> 
#include<ctime> 

int main() 
{ 
    std::time_t t = std::time(0); // t is an integer type 
    std::cout << t << " seconds since 01-Jan-1970\n"; 
    return 0; 
} 
+0

這假定'std :: time()'自1970年以來就有了幾秒鐘的時間。在很多系統上(POSIX和Windows,我相信)都是如此,但語言標準並不能保證這一點。 – 2016-06-24 02:44:34

6
#include <iostream> 
#include <sys/time.h> 

using namespace std; 

int main() 
{ 
    unsigned long int sec= time(NULL); 
    cout<<sec<<endl; 
} 
+0

'time()'返回'time_t'類型的結果,原型可以是有符號的,無符號的,甚至是浮點的。爲什麼要將結果存儲在'long int'中?爲什麼使用''而不是標準''? – 2016-06-24 02:43:52

+0

我明白,但我認爲在任何兼容POSIX的OS中都存在time.h和sys/time.h。 同樣你也完全正確,time_t也可以是負值,因爲它表示爲從1970-01-01T00:00Z過去的秒數。 – anijhaw 2016-06-27 20:20:01

13

最常見的意見是錯的,你不能僅僅依靠time()。這是用於相對時間:ISO C++沒有指定1970-01-01T00:00Ztime_t(0)

更糟糕的是,你不能容易地弄清楚,要麼。當然,你可以找到time_t(0)的日曆日期gmtime,但是如果是2000-01-01T00:00Z,你會怎麼做? 1970-01-01T00:00Z2000-01-01T00:00Z之間有幾秒鐘?由於閏秒,它當然不是60的倍數。

+1

「如何在C++中獲得uint unix時間戳?」 - 給定 - 如你所說 - 你可以稍後調用'gmtime()'來獲得任何時間戳編碼的可讀表示,不管參考引用是什麼,time()都不能滿足問題中請求的功能日期或適用於區間計算? – 2012-08-23 06:58:54

+3

要在非UNIX系統上獲得** UNIX **時間戳,您必須知道本地時期和「1970-01-01T00:00Z」之間的差異(以秒爲單位)。沒有辦法做到這一點。 – MSalters 2012-08-23 07:48:54

+0

出於某種原因,我得到的印象是在UNIX(或Linux等)機器上的代碼問題,但現在我看到你來自哪裏。好奇:你有沒有發現time_t(0)不是1970-01-01T00:00Z的實際系統?只需幾分鐘即可解決任何給定系統上的偏移量問題(在UNIX系統上使用非UNIX time_t(0)並獲取time_t),但感謝您解釋您的擔憂。 – 2012-08-23 23:35:37

1

我創建了一個全球定義更多的信息:

#include <iostream> 
#include <ctime> 
#include <iomanip> 

#define INFO std::cout << std::put_time(std::localtime(&time_now), "%y-%m-%d %OH:%OM:%OS") << " [INFO] " << __FILE__ << "(" << __FUNCTION__ << ":" << __LINE__ << ") >> " 
#define ERROR std::cout << std::put_time(std::localtime(&time_now), "%y-%m-%d %OH:%OM:%OS") << " [ERROR] " << __FILE__ << "(" << __FUNCTION__ << ":" << __LINE__ << ") >> " 

static std::time_t time_now = std::time(nullptr); 

使用方法如下:

INFO << "Hello world" << std::endl; 
ERROR << "Goodbye world" << std::endl; 

採樣輸出:

16-06-23 21:33:19 [INFO] src/main.cpp(main:6) >> Hello world 
16-06-23 21:33:19 [ERROR] src/main.cpp(main:7) >> Goodbye world 

將這些行放在頭文件中。我發現這對於調試非常有用。

+0

爲什麼'#define'而不是函數?功能將更加靈活,可重載,更明顯的鋤頭使用... – Troyseph 2017-09-21 15:41:09

+1

@Troyseph因爲'__FILE__'____FUNCTION__''__LINE__'不會按預期工作。這是一個宏。 – xinthose 2017-09-22 04:28:57

+1

夠公平!恥辱沒有一個更現代的選擇=] – Troyseph 2017-09-22 10:53:34