>백엔드 개발 >C++ >C에서 코드 실행 시간을 어떻게 정확하게 측정할 수 있습니까?

C에서 코드 실행 시간을 어떻게 정확하게 측정할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-28 13:58:121016검색

How Can I Precisely Measure Code Execution Time in C  ?

C에서 실행 시간을 정밀하게 측정

코드 성능을 최적화하려면 정확한 실행 시간 측정이 필수적입니다. C에서 clock() 함수는 경과 시간을 계산하는 방법을 제공합니다. 그러나 짧은 코드 조각을 사용하면 신뢰할 수 없는 결과가 반환될 수 있습니다.

clock()의 제한 사항

입력이 작거나 한 줄로 된 문의 경우 clock()이 실행을 보고하는 경우가 많습니다. "0초"의 시간입니다. 이러한 불일치는 clock() 함수가 시스템에 따라 밀리초 또는 나노초 단위로 세분화되어 있기 때문에 발생합니다. 이 세분성보다 짧은 실행 기간의 경우 clock()은 0으로 내림됩니다.

해결책: GetTimeMs64() 사용

이 제한을 극복하려면 유틸리티 함수 사용을 고려하십시오. GetTimeMs64(). 이 함수는 Unix epoch 이후 경과된 시간을 밀리초 단위로 정확하게 측정하고 Windows 및 Linux 플랫폼 모두에서 작동합니다.

GetTimeMs64() 함수는 GetSystemTimeAsFileTime()을 사용하여 Windows의 시스템 시계를 활용합니다. Linux에서는 gettimeofday()를 사용하여 현재 시간을 검색합니다. 얻은 값을 밀리초로 변환하고 Unix epoch에서 오프셋을 빼서 Unix 시간 표준에 맞춥니다.

구현

GetTimeMs64()를 사용하려면 다음을 포함하면 됩니다. 프로그램에 다음 코드를 추가하세요.

#include <Windows.h>
// or
#include <sys/time.h>
#include <ctime>

uint64 GetTimeMs64()
{
    // Code from provided solution goes here
}

실행 시간을 계산하려면 코드 조각의 예:

  1. 코드를 실행하기 전에 GetTimeMs64()를 호출하세요.
  2. 코드를 실행하세요.
  3. 코드를 실행한 후 다시 GetTimeMs64()를 호출하세요.
  4. 두 번째 시간에서 첫 번째 시간을 빼서 경과 시간을 구합니다. 밀리초.

사용 예:

uint64 startTime = GetTimeMs64();
// Your code here
uint64 endTime = GetTimeMs64();
cout << "Execution time: " << (endTime - startTime) / 1000.0 << " seconds" << endl;

이 방법은 작은 코드 조각이나 짧은 명령문에 대해서도 정확한 실행 시간 측정을 제공합니다. 이를 통해 개발자는 코드를 효과적으로 최적화하고 성능 향상을 정확하게 측정할 수 있습니다.

위 내용은 C에서 코드 실행 시간을 어떻게 정확하게 측정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.