我使用此代码来跟踪上次重启:
+ (float) secondsSinceLastReboot{
return ((float)(mach_absolute_time())) * ((float)timebase.numer) / ((float)timebase.denom) / 1000000000.0f;
}
我假设mach_absolute_time()基于上次设备启动时间,就像在mac上一样。它似乎不是基于此。我实际上根本不知道它是基于什么。
请看以下行为(今天的日期是2009-09-20):
lastRebootTime = [[NSDate date] addTimeInterval:-[self secondsSinceLastReboot]];
//last Reboot Time will contain : 2009-09-20 07:42:14 +0100
我绝对肯定我当时没有重启我的设备。我的设备一周内没有启动。
此外,当我从电缆上取下设备并运行此应用程序时,似乎当设备进入休眠状态时,lastRebootTime将来会开始转移。似乎mach_absolute_time没有考虑睡眠时间。或者我错了吗?
我真的希望能够从设备上次重启时获取时间戳。有什么想法吗?
答案 0 :(得分:47)
我自己也遇到了一些麻烦。没有很多好的文档,所以我选择了实验。这是我能够确定的:
mach_absolute_time取决于设备的处理器。它返回自上次重启设备以来的刻度(也称为正常运行时间)。为了以人类可读的形式获取它,您必须通过mach_timebase_info(比率)的结果对其进行修改,该结果将返回十亿分之一秒(或纳秒)。为了使它更有用,我使用如下所示的函数:
#include <mach/mach_time.h>
int getUptimeInMilliseconds()
{
const int64_t kOneMillion = 1000 * 1000;
static mach_timebase_info_data_t s_timebase_info;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
(void) mach_timebase_info(&s_timebase_info);
});
// mach_absolute_time() returns billionth of seconds,
// so divide by one million to get milliseconds
return (int)((mach_absolute_time() * s_timebase_info.numer) / (kOneMillion * s_timebase_info.denom));
}
答案 1 :(得分:9)
如果您对计算时间不太关心,可以使用Foundation中的简单Obj-C类
NSTimeInterval systemUptime = [[NSProcessInfo processInfo] systemUptime];
答案 2 :(得分:1)
万一有人在Swift中需要它(在4.2和5.0中可用)。
let beginTime = mach_absolute_time()
// do something...
var baseInfo = mach_timebase_info_data_t(numer: 0, denom: 0)
if mach_timebase_info(&baseInfo) == KERN_SUCCESS {
let finiTime = mach_absolute_time()
let nano = (finiTime - beginTime) * UInt64(baseInfo.numer) / UInt64(baseInfo.denom)
}