有没有办法在c语言中使用time.h从1970年获得毫秒及其分数?
答案 0 :(得分:36)
这适用于Ubuntu Linux:
#include <sys/time.h>
...
struct timeval tv;
gettimeofday(&tv, NULL);
unsigned long long millisecondsSinceEpoch =
(unsigned long long)(tv.tv_sec) * 1000 +
(unsigned long long)(tv.tv_usec) / 1000;
printf("%llu\n", millisecondsSinceEpoch);
在撰写本文时,上面的printf()给了我1338850197035.您可以在TimestampConvert.com网站上进行健全性检查,您可以输入该值以获取相同的人类可读时间(虽然没有毫秒精度。)
答案 1 :(得分:9)
如果你想要毫秒级的分辨率,你可以在Posix中使用gettimeofday()。对于Windows实施,请参阅gettimeofday function for windows。
#include <sys/time.h>
...
struct timeval tp;
gettimeofday(&tp);
long int ms = tp.tv_sec * 1000 + tp.tv_usec / 1000;
答案 2 :(得分:6)
它不是标准C,但是gettimeofday()
存在于SysV和BSD派生系统中,并且位于POSIX中。它会在struct timeval
:
struct timeval {
time_t tv_sec; /* seconds */
suseconds_t tv_usec; /* microseconds */
};
答案 3 :(得分:4)
对于Unix和Linux,您可以使用gettimeofday。
对于Win32,您可以使用GetSystemTimeAsFileTime,然后使用convert it to time_t + milliseconds。
答案 4 :(得分:2)
// the system time
SYSTEMTIME systemTime;
GetSystemTime( &systemTime );
// the current file time
FILETIME fileTime;
SystemTimeToFileTime( &systemTime, &fileTime );
// filetime in 100 nanosecond resolution
ULONGLONG fileTimeNano100;
fileTimeNano100 = (((ULONGLONG) fileTime.dwHighDateTime) << 32) + fileTime.dwLowDateTime;
//to milliseconds and unix windows epoche offset removed
ULONGLONG posixTime = fileTimeNano100/10000 - 11644473600000;
return posixTime;
答案 5 :(得分:1)
Unix time or Posix time是您提到的纪元以来秒的时间。
bzabhi的答案是正确的:你只需将Unix时间戳乘以1000就可以得到毫秒。
请注意,依赖于Unix时间戳返回的所有毫秒值都将是倍数 1000(如12345678000)。分辨率仍然只有1秒。
您无法获得小数部分
Pavel的评论也是正确的。 Unix时间戳没有考虑闰秒。这使得依赖转换为毫秒更为明智。