我想知道是否有一种简单的方法可以在原生Android代码中获取当前时间。最好,它可以与System.getTimeMillies()相媲美。我将只使用它来查看某些函数调用将花费多长时间,因此当前时间为毫秒的长变量将是我的最佳解决方案。
提前感谢!
发布于 2010-10-02 02:23:36
对于微秒分辨率,您可以使用gettimeofday()
。这使用“挂钟时间”,当设备处于睡眠状态时,它会继续前进,但如果网络更新了设备的时钟,它就会突然向前或向后移动。
您也可以使用clock_gettime(CLOCK_MONOTONIC)
。这使用单调时钟,它从不向前或向后跳跃,而是在设备休眠时停止计数。
计时器的实际分辨率取决于设备。
这两个API都是POSIX API,而不是特定于Android的。
发布于 2013-01-14 10:55:42
对于懒惰的人,将以下代码添加到您的代码顶部:
#include <time.h>
// from android samples
/* return current time in milliseconds */
static double now_ms(void) {
struct timespec res;
clock_gettime(CLOCK_REALTIME, &res);
return 1000.0 * res.tv_sec + (double) res.tv_nsec / 1e6;
}
这样叫它:
double start = now_ms(); // start time
// YOUR CODE HERE
double end = now_ms(); // finish time
double delta = end - start; // time your code took to exec in ms
发布于 2017-03-21 22:29:28
另一个用于惰性的函数,该函数使用CLOCK_MONOTONIC
返回以纳秒为单位的当前时间
#include <time.h>
#define NANOS_IN_SECOND 1000000000
static long currentTimeInNanos() {
struct timespec res;
clock_gettime(CLOCK_MONOTONIC, &res);
return (res.tv_sec * NANOS_IN_SECOND) + res.tv_nsec;
}
https://stackoverflow.com/questions/3832097
复制相似问题