比毫秒System.currentTimeMillis()更精确的时间戳(纳米级时间戳)

纳秒

  ns(nanosecond):纳秒,  时间单位。一秒的10亿分之一,即等于10的负9次方秒。常用作  内存读写速度的单位,其前面数字越小则表示速度越快。
  1纳秒=1000  皮秒 
  1纳秒 =0.001   微秒
  1纳秒=0.000001  毫秒

  1纳秒=0.00000 0001

java的System.currentTimeMillis()和System.nanoTime()有什么区别

java中System.nanoTime()返回的是纳秒,nanoTime而返回的可能是任意时间,甚至可能是负数……按照API的说明,nanoTime主要的用途是衡量一个时间段,比如说一段代码执行所 用的时间,获取数据库连接所用的时间,网络访问所用的时间等。另外,nanoTime提供了纳秒级别的精度,但实际上获得的值可能没有精确到纳秒。

但总的来说,这两个函数的用途是完全不一样的!

java中System.currentTimeMillis()返回的毫秒,这个毫秒其实就是自1970年1月1日0时起的毫秒数,Date()其实就是相当于Date(System.currentTimeMillis());因为Date类还有构造Date(long date),用来计算long秒与1970年1月1日之间的毫秒差。


[摘要:比来项目开辟,须要猎取到当前时光而且切确到微秒。然则一查材料发明乎只能切确到到毫秒级,经过 SimpleDateFormat formatter = new SimpleDateFormat(yyyyMMddHHmmssSSS); String str = formatter.format(new]

最近项目开发,需要获取到当前时间并且精确到微秒。但是一查资料发现似乎只能精确到到毫秒级,通过

SimpleDateFormat formatter = new SimpleDateFormat("yyyyMMddHHmmssSSS");

        String str = formatter.format(new Date());

或者

Calendar calendar = Calendar.getInstance();
        long mm = calendar.get(Calendar.MILLISECOND);

最后几经周折,可以通过c代码得到得到当前时间的微秒值,于是便通过jni方式得到了时间的微秒值。

其中c代码:

JNIEXPORT jlongArray JNICALL Java_com_test_ndkhelloword_MainActivity_getTimesFromJni(
        JNIEnv *env, jobject thiz) {
    jlongArray time = env->NewLongArray(2);
    jlong temp[] = { 0, 0 };
    struct timeval begin;
    gettimeofday(&begin, NULL);
    temp[0] = begin.tv_sec;
    temp[1] = begin.tv_usec;
    env->SetLongArrayRegion(time, 0, 2, temp);
    return time;
}

还好最后找到了办法,特此分享。


你可能感兴趣的:(Android_UI,java,盲区)