[Java] 코드 실행시간 측정
by 배부른코딩로그💡 1초 이상 기다려주는 고객은 거의 없다. 고객을 사로잡는 서비스는 대부분 빠른 서비스를 제공할 것이다!
목표
- 특정 기능에 대한 실행 시간을 측정할 수 있다.
- Java 기반의 프레임워크를 사용하면서 수행 시간 테스트 함에 있어서 도입할 수 있다.
어플리케이션을 개발 및 유지보수하면서 코드 실행 시간을 측정을 해야할 일은 항상 생기곤 한다.
개발 과정 중 특정 기능의 수행 속도 개선이나, 성능 테스트에 대한 지표는 당연 실행 시간이기 때문이다.
Java에서 코드 실행 시간을 측정할 때 사용할 수 있는 방법은 다음과 같다.
- System.currentTimeMillis() : 가장 간단한 실행 시간 측정 방법
- System.nanoTime() : 정밀하게 실행 시간을 측정하는 방법
- Instant.now() : Java8에서 도입된 클래스로 실행 시간 측정
1) System.currentTimeMillis()
currentTimeMillis()는 UTC 시간을 밀리초(ms) 단위로 리턴한다. 다음과 같이 코드 실행 시간을 측정할 수 있다.
(※ UTC는 1970년 1월 1일을 기준으로 현재의 시간을 측정한 값)
public class PerformanceTime {
public static void main(String[] args) {
long startTime = System.currentTimeMillis();
for (long i = 0; i < 1000000000; i++) {
long pow = i * i;
}
long finishTime = System.currentTimeMillis();
long elapsedTime = finishTime - startTime;
System.out.println("elapsedTime(ms) : " + elapsedTime); // 1s = 1,000ms
}
}
결과:
elapsedTime(ms) : 122
2) System.nanoTime()
System.nanoTime()는 시스템(JVM) 시간을 나노초(ns) 단위로 리턴한다.
currentTimeMillis() 보다 더 정밀한 측정이 필요한 경우 사용한다. 필자는 99% nanoTime()을 사용한다.
public class PerformanceTime {
public static void main(String[] args) {
long startTime = System.nanoTime();
for (long i = 0; i < 1000000000; i++) {
long a = i * i;
}
long finishTime = System.nanoTime();
long elapsedTime = finishTime - startTime;
System.out.println("elapsedTime(ns) : " + elapsedTime); // 1s = 1000,000,000ns
}
}
(※ 셀프Q&A 1s = 1000,000μs "1초는 1000,000마이크로초와 같다")
결과:
elapsedTime(ns) : 203226148
3) Instant.now()
Java8 버전 이후부터 사용할 수 있는 API이다. 사용법이 다음과 같이 아주 편하고 직관적이다.
public class EasyPerformanceTime {
public static void main(String[] args) {
Instant start = Instant.now();
for (long i = 0; i < 1000000000; i++) {
long a = i * i;
}
Instant finish = Instant.now();
long elapsedTime = Duration.between(start, finish).toMillis();
System.out.println("elapsedTime(ms) : " + elapsedTime);
}
}
결과:
elapsedTime(ms) : 282
번외
StopWatch (Apache Commons Lang API)
StopWatch는 Apache에서 제공하는 클래스로 의존성을 추가해야 한다.
다음과 같이 코드 실행 시간을 측정할 수 있다.
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.12.0</version>
</dependency>
import org.apache.commons.lang3.time.StopWatch;
public class EasyPerformanceTime {
public static void main(String[] args) {
StopWatch stopWatch = new StopWatch();
stopWatch.start();
for (long i = 0; i < 1000000000; i++) {
long a = i * i;
}
stopWatch.stop();
System.out.println("elapsedTime(ns) : " + stopWatch.getNanoTime());
}
}
결과:
266362481
출처
- "자바에서 코드 실행 시간을 측정하는 방법", Kimtaeng, 2020-09-19
- "자바 nanotime(나노시간)을 second(초)로 변환하기", 행복한디벨로퍼, 2018-02-06
Last Updated. 2022. 03. 22.
반응형
'Java' 카테고리의 다른 글
[Java] Properties 한글 깨짐 이슈 (0) | 2022.10.25 |
---|---|
[Java] 특정 디렉토리 및 파일 모니터링 (0) | 2022.06.10 |
[Java] 파일 입출력 소화하기 (0) | 2022.06.09 |
[Java] Lombok 소화하기 (0) | 2022.06.07 |
[Java] Null Safe한 자바 컬렉션 정렬 (0) | 2022.05.24 |
블로그의 정보
배부른코딩로그
배부른코딩로그