pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>Spring-StopWatch</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
</dependencies>
</project>
Application.java
package com.example;
import org.springframework.util.StopWatch;
import java.util.HashMap;
import java.util.Map;
public class Application {
public static void main(String[] args) {
StopWatch stopWatch = new StopWatch("StopWatch-Demo");
stopWatch.start("task-1");
// 核心代码1
// 这里模拟业务逻辑
Map<String,Integer> testMap1 = new HashMap<>();
for(int i =0; i < 1000000;i++){
testMap1.put(String.format("%s",i),i);
}
stopWatch.stop();
stopWatch.start("task-2");
// 核心代码2
// 这里模拟业务逻辑
Map<String,Integer> testMap2 = new HashMap<>();
for(int i =0; i < 1000000;i++){
testMap2.put(String.format("%s",i),i);
}
stopWatch.stop();
System.err.println(stopWatch.prettyPrint());
}
}
测试结果:
StopWatch 'StopWatch-Demo': running time = 2828227051 ns
---------------------------------------------
ns % Task name
---------------------------------------------
1712670744 061% task-1
1115556307 039% task-2