0

0

Java怎么统计线程执行时间 Java测量多线程耗时方法【实战】

畫卷琴夢

畫卷琴夢

发布时间:2026-03-06 04:31:29

|

129人浏览过

|

来源于php中文网

原创

system.nanotime()最准,因其基于单调递增高精度计时器,不受系统时钟调整影响;应在线程内部起止处调用,避免测调度开销,多线程需countdownlatch同步起点,线程池任务宜用future结合内部nanotime()分离排队与执行时间,并注意jit预热和gc干扰。

java怎么统计线程执行时间 java测量多线程耗时方法【实战】

System.nanoTime() 测单个线程执行时间最准

毫秒级的 System.currentTimeMillis() 在多线程场景下容易受系统时钟调整影响,导致负数或跳变;而 System.nanoTime() 基于单调递增的高精度计时器,不受系统时间修改干扰,适合测量耗时。

实操建议:

  • 在目标线程内部起始位置调用 long start = System.nanoTime();
  • 在结束位置调用 long end = System.nanoTime();,再计算 (end - start) / 1_000_000.0 得到毫秒值(保留小数更利于观察微小差异)
  • 避免把 nanoTime() 调用放在 Thread.start() 之前或 join() 之后——那测的是调度开销,不是线程体真实执行时间

多个线程统一计时要用 CountDownLatch + 共享开始时间戳

如果想对比多个线程从“同一时刻”启动到各自完成的耗时,不能让每个线程自己调用 System.nanoTime() 获取起点——线程调度有延迟,起点实际不同。

正确做法是:主线程预设开始时间,用 CountDownLatch 同步所有工作线程的启动时机:

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

问小白
问小白

免费使用DeepSeek满血版

下载
long startTime = System.nanoTime();
CountDownLatch latch = new CountDownLatch(1);
List<Thread> threads = new ArrayList<>();
for (int i = 0; i < 3; i++) {
    threads.add(new Thread(() -> {
        try { latch.await(); } catch (InterruptedException e) { return; }
        long start = System.nanoTime(); // 所有线程此时才真正开始计时
        // ... 执行任务
        long cost = System.nanoTime() - start;
        System.out.println("Thread " + Thread.currentThread().getId() + ": " + cost / 1_000_000.0 + "ms");
    }));
}
threads.forEach(Thread::start);
latch.countDown(); // 统一放行
threads.forEach(t -> { try { t.join(); } catch (InterruptedException e) {} });

ExecutorService + Future 测异步任务总耗时和各任务耗时

实际项目中多用线程池而非裸线程,这时推荐封装任务为 Callable,利用 Future.get() 的阻塞特性自然捕获执行完成时间。

关键点:

  • 主线程调用 submit() 后立刻记录开始时间,get() 返回时记录结束时间,得到该任务端到端耗时(含排队+执行)
  • 若要单独看“纯执行时间”,需在 Callable.call() 内部用 System.nanoTime() 计时,并把结果作为返回值的一部分
  • 注意 Future.get(long, TimeUnit) 可能抛出 TimeoutException,需显式处理,否则会掩盖超时问题

别忽略 JIT 预热和 GC 干扰

刚启动的 JVM 中,短小方法可能还没被 JIT 编译,首次执行慢;频繁创建对象又可能触发 GC,导致某次测量突然飙升几十毫秒——这些都不是业务逻辑的真实开销。

实战建议:

  • 做性能测试前,先用相同逻辑空跑 1~2 万次(warm-up),让热点代码被编译、类被加载、缓存被填充
  • -XX:+PrintGCDetails 观察日志,确认测量期间没发生 full GC
  • 单次测量不可信,应运行多次(如 100 次),取中位数或 p95 值,比平均值更能反映典型表现

线程时间测量真正难的不是写那两行 nanoTime(),而是确保你测的确实是想测的那个“时间”——启动时机、上下文切换、JIT、GC、锁竞争,全都会悄悄掺进去。不控制变量,数字再精确也没意义。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

375

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

27

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

102

2026.02.06

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

375

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

27

2026.01.21

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

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

精品课程

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

共23课时 | 4.2万人学习

C# 教程
C# 教程

共94课时 | 10.8万人学习

Java 教程
Java 教程

共578课时 | 77.8万人学习

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

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