0

0

在Java中System.nanoTime如何精确测量时间_Java高精度计时工具解析

P粉602998670

P粉602998670

发布时间:2026-02-06 12:44:02

|

239人浏览过

|

来源于php中文网

原创

System.nanoTime()仅提供单调递增纳秒值,适合测间隔而非时间戳;其差值为0因分辨率低、JIT优化或调用开销大;不可与currentTimeMillis()混用;微基准测试需预热、避GC、保内联、多次测量。

在java中system.nanotime如何精确测量时间_java高精度计时工具解析

System.nanoTime() 本身不提供“绝对时间”,它只返回一个单调递增的纳秒级计时值,适合测间隔,不适合做时间戳。它的精度和稳定性取决于底层操作系统与硬件,不是所有平台都能真正达到纳秒级分辨率。

为什么 System.nanoTime() 测出来的时间差有时为 0

常见现象:连续两次调用 System.nanoTime() 相减得 0,尤其在空循环或极短操作中。

  • 底层计时器分辨率有限(如 Windows 上常为 10–15ms,Linux 可能是 1–10ns,但受 CPU 频率调节、虚拟化影响)
  • JIT 编译可能优化掉“无副作用”的代码段,导致实际没执行
  • 单次调用开销本身就可能接近或超过计时器最小可分辨间隔
  • 建议至少重复测量 100 次以上取平均,并用 Thread.onSpinWait() 或简单 volatile 读写防止过度优化

System.nanoTime()System.currentTimeMillis() 能否混用

绝对不能。两者基准不同、更新机制不同、用途完全不同。

  • System.currentTimeMillis() 返回自 1970-01-01 UTC 的毫秒数,受系统时钟调整(NTP、手动修改)影响,可能回跳或跳跃
  • System.nanoTime() 基于某个未公开起点(如 JVM 启动时刻),只保证单调性,不映射到真实时间
  • System.nanoTime() 减去一个 System.currentTimeMillis() 值毫无意义,结果单位错乱且语义失效
  • 日志打点若需“带时间戳的耗时”,应分别记录 System.currentTimeMillis()(用于排序/对齐)和 System.nanoTime()(用于精确差值)

在微基准测试中如何避免 System.nanoTime() 的典型误用

JMH 是首选,但若手写简易 benchmark,必须绕过几个关键陷阱:

Pebblely
Pebblely

AI产品图精美背景添加

下载

立即学习Java免费学习笔记(深入)”;

  • 预热不足:JVM 需要数万次执行才能完成 JIT 编译,首次测得的值严重失真
  • 没有隔离 GC 干扰:一次 System.gc() 可能打断测量;建议用 -XX:+PrintGCDetails 观察是否发生 GC
  • 忽略方法内联限制:被测方法太长或含分支/异常,JIT 可能拒绝内联,引入额外 call 开销
  • 错误地把多次调用合并成一次测量:例如 for (int i = 0; i 然后只包一层 nanoTime() —— 这测的是整体耗时,无法归一化到单次,应改为 long start = System.nanoTime(); for (...) { work(); } long end = System.nanoTime(); 再除以 N

最易被忽略的一点:System.nanoTime() 在某些容器环境(尤其是启用了 CPU quota 的 Docker)下会出现非线性漂移,表现为相同代码在不同运行周期测出差异达几十纳秒——这不是 Java 的问题,而是 Linux cfs_bandwidth 的调度抖动所致,此时应考虑用 CLOCK_MONOTONIC_RAW(需 JNI)或接受误差范围。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

585

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

550

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

153

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

204

2025.08.29

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.10.23

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

87

2025.12.01

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

952

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1137

2023.07.27

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

21

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.6万人学习

Git 教程
Git 教程

共21课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号