比毫秒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;
}

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


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值