好玩的东东(Stopwatch类)

作者在VB.net(2005)中进行了一项计时测试,使用了Stopwatch类来测量时间间隔,并发现了实际结果与预期存在较大偏差,大约为两倍的关系。此现象可能与双核处理器有关。

我在VB.net(2005)中,写了下面的东西,很奇怪,运行结果明显不对。

 

显示的结果,差不多是两倍的关系,有人遇到过不?

难道是因我的的机器是双核的?

<think> 根据用户的问题和提供的引用内容,用户想了解Java中StopWatch的使用方法和相关信息。结合引用内容,我将整理StopWatch的基本用途、不同实现版本(Apache Commons Lang和Spring Framework)的使用方法,并提供示例代码。 注意:引用中提到了两种StopWatch,一种是org.apache.commons.lang3.time.StopWatch(来自Apache Commons Lang),另一种是org.springframework.util.StopWatch(来自Spring Framework)。需要明确区分。 回答结构: 1. StopWatch简介(用途) 2. Apache Commons Lang中的StopWatch使用 3. Spring Framework中的StopWatch使用 4. 两者的区别 5. 使用场景 同时,按照系统级指令要求,数学公式要用$...$,独立公式用$$...$$,但由于本问题不涉及数学公式,所以主要关注代码示例和中文回答。 另外,需要生成相关问题。 </think> ### Java StopWatch详解 StopWatch是Java中用于代码性能分析的计时工具,主要用途是精确测量代码段的执行时间。以下是核心知识点: --- #### 1. **核心功能** - 精确计时:记录代码段的执行时间(纳秒/毫秒级精度) - 分段计时:支持多个任务的独立计时(Spring版本特有) - 结果格式化:自动生成易读的时间统计报告 - 用途:性能优化、算法效率分析、监控代码执行瓶颈 --- #### 2. **不同实现版本** **(1) Apache Commons Lang实现** ```java import org.apache.commons.lang3.time.StopWatch; public class ApacheExample { public static void main(String[] args) throws InterruptedException { StopWatch stopWatch = new StopWatch(); stopWatch.start(); // 启动计时 // 模拟业务代码 Thread.sleep(150); stopWatch.stop(); // 停止计时 System.out.println("执行时长: " + stopWatch.getTime() + "毫秒"); } } ``` ► 特点:简单计时,需手动启停 ► 输出:`执行时长: 150毫秒` **(2) Spring Framework实现** ```java import org.springframework.util.StopWatch; public class SpringExample { public static void main(String[] args) throws InterruptedException { StopWatch sw = new StopWatch("性能测试"); sw.start("数据库查询"); Thread.sleep(100); sw.stop(); sw.start("数据处理"); Thread.sleep(200); sw.stop(); System.out.println(sw.prettyPrint()); } } ``` ► 特点:支持多任务分段计时 ► 输出: ``` StopWatch '性能测试': running time = 300 ms ----------------------------------------- ms % Task name 0100 033% 数据库查询 0200 067% 数据处理 ``` --- #### 3. **核心方法对比** | 方法 | Apache | Spring | 作用 | |---------------------|--------------|---------------|--------------------------| | `start()` | ✓ | ✓ | 开始计时 | | `stop()` | ✓ | ✓ | 停止计时 | | `getTime()` | ✓ | ✓ | 获取总耗时(毫秒) | | `prettyPrint()` | ✗ | ✓ | 格式化输出分段结果 | | `getTaskCount()` | ✗ | ✓ | 获取任务分段数量 | | `suspend()`/`resume()` | ✓ | ✗ | 暂停/恢复计时(Apache特有)| --- #### 4. **使用场景** 1. 算法性能优化(如排序算法耗时对比) 2. 数据库查询效率分析 3. 微服务接口响应时间监控 4. 多线程任务执行时间统计 5. 批处理作业分段耗时诊断 > 📌 最佳实践:生产环境推荐结合日志框架(如SLF4J)输出计时结果,避免直接使用`System.out`[^1][^3]。 --- #### 5. **注意事项** 1. **非线程安全**:单个StopWatch实例不能在多线程间共享 2. **计时精度**:底层使用`System.nanoTime()`,但受操作系统调度影响 3. **开销控制**:频繁创建实例可能影响性能,建议重用对象 4. **版本差异**:Spring版功能更丰富,但需引入Spring-core依赖 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值