찾다
백엔드 개발PHP 튜토리얼PHP의 고정밀 타이머 HRTime 확장에 대한 자세한 설명

학교 체육 시험 때 선생님이 가져온 스톱워치를 아직도 기억하시나요? 총소리가 들리면 우리는 달리기 시작했고, 결승선을 통과하면 교사가 버튼을 눌러 결과를 기록했습니다. 오늘 우리가 배울 내용은 사실 이번 스포츠 테스트의 스톱워치와 유사한 기능적 확장입니다. 바로 PHP의 HRTime 확장입니다.

Clock Beat

먼저 시스템의 클럭 비트가 무엇인지 이해해야 합니다. Linux 시스템이 시작되면 시계 메트로놈이 동시에 시작되어 나노초 단위로 타이밍을 측정하며 HRTime 확장의 실제 이름은 High Precision Time 확장입니다. 즉, 나노초 단위로 타이밍을 측정할 수 있는 운영체제 기반의 시계 메트로놈이다.

1초 = 1000밀리초 = 1000000마이크로초 = 1000000000나노초 이것이 얼마나 정확한지 알 수 있는 초, 밀리초, 마이크로초입니다. 1초는 10억 나노초와 같으므로 매우 정확한 시간 간격을 계산할 수 있습니다.

HRTime 확장은 PECL에서 직접 다운로드하여 설치할 수 있습니다. 다른 일반 확장과 다르지 않습니다.

시스템 시계 틱 정보 가져오기 Ticks

먼저 운영 체제의 시계 틱을 가져오는 방법, 즉 이 Ticks를 살펴보겠습니다. 그 내용에 관해서는 이미 많은 학생들이 운영 체제를 배울 때 접해 본 적이 있을 것입니다. 여기에서는 HRTime 확장을 사용하여 이를 얻는 방법을 살펴보겠습니다.

print_r(hrtime());
// Array
// (
//     [0] => 3758
//     [1] => 407409171
// )

echo hrtime(true), PHP_EOL;
// 3758407428932

hrtime() 이 함수는 PHP7 이후 기본 PHP 환경에 통합되었습니다. HRTime 확장을 사용할 필요는 없습니다. 이 함수는 매개변수 없이 배열을 반환합니다. 0번째 항목은 시스템이 시작된 이후의 시간(초)이고, 첫 번째 항목은 해당 나노초 수입니다. 매개변수가 true로 설정되면 초와 나노초가 연결된 실제 나노초 타임스탬프를 직접 반환합니다.

echo HRTime\PerformanceCounter::getFrequency(), PHP_EOL; // 1000000000
echo HRTime\PerformanceCounter::getTicks(), PHP_EOL; // 3758428256236
echo HRTime\PerformanceCounter::getTicksSince(1212), PHP_EOL; // 3758428257494

$a = HRTime\PerformanceCounter::getTicks();
echo HRTime\PerformanceCounter::getTicksSince($a), PHP_EOL; // 412

다음 세 함수는 HRTime 확장에 있는 PerformanceCounter 개체의 정적 함수입니다. PerformanceCounter 객체는 성능 카운터를 의미하며, getFrequency()는 타이머 빈도(틱/초)를 나타내는데 나노초 단위인 10억을 반환하는 것을 볼 수 있습니다. getTicks()는 현재 시계 틱 시간을 반환하며, 그 결과는 시스템 시작 후 반환되는 시계 틱 시간인 hrtime(true) 함수와 동일함을 알 수 있습니다. getTicksSince() 메소드는 지정된 나노초 수를 기반으로 시간 간격을 반환하며 이는 실제로 time() - time() 작업과 유사합니다. 이 방법을 통해 두 코드 실행 사이의 시간 간격을 얻을 수 있으며 단위는 나노초입니다.

타이머 기능

다음 단계는 우리 기사의 초점인 타이머 기능의 구현입니다. 위에서 언급한 것처럼 getTickSince()를 사용하면 실제로 코드 조각의 실행 시간 간격을 모니터링할 수 있지만 아래에서 배우게 될 내용이 더 강력해집니다.

$c = new HRTime\StopWatch;

$c->start();
for ($i = 0; $i isRunning(), PHP_EOL; // isRunning: 1
$c->stop();

echo 'Time NS: ', $c->getLastElapsedTime(HRTime\Unit::NANOSECOND), PHP_EOL;
echo 'Time US: ', $c->getLastElapsedTime(HRTime\Unit::MICROSECOND), PHP_EOL;
echo 'Time MS: ', $c->getLastElapsedTime(HRTime\Unit::MILLISECOND), PHP_EOL;
echo 'Time S: ', $c->getLastElapsedTime(HRTime\Unit::SECOND), PHP_EOL;
// Time NS: 6929888
// Time US: 6929.888
// Time MS: 6.929888
// Time S: 0.006929888

echo 'Ticks: ',$c->getLastElapsedTicks(), PHP_EOL;
// Ticks: 6929888

echo 'isRunning: ',$c->isRunning(), PHP_EOL;
//

StopWatch 개체를 인스턴스화한 다음 타이머가 시작되도록 start() 메서드를 호출해야 합니다. StopWatch의 영어 의미 자체가 타이머의 의미이므로 이 개체는 타이머의 작동을 지원하도록 특별히 설계되었습니다. isRunning() 메서드를 통해 현재 타이머가 실행 중인지 확인할 수 있습니다. 실제로는 현재 타이머가 start() 및 stop(의 범위 내에 있지 않은 경우)인지 확인하는 것입니다. ), 그러면 false를 반환합니다. 테스트 코드에서는 1024*1024의 빈 루프를 실행한 다음 stop() 메서드를 사용하여 타이머를 종료합니다.

코드에서 볼 수 있듯이 getLastElapsedTime()은 위 코드의 start()와 stop() 사이의 시간 간격 정보를 얻는 것입니다. 해당 매개변수는 초, 밀리초, 마이크로초, 나노초로 지정할 수 있습니다. 이 방법 자체의 의미는 마지막 간격의 실행 시간을 얻는 것입니다. getLastElapsedTicks()는 마지막 간격의 시계 틱 정보를 가져옵니다. [마지막 시간]이라는 단어가 4개이므로 분할된 타이밍을 위해 이 개체를 여러 번 호출할 수 있다는 의미입니다. 또한 모든 시간 간격 정보를 얻기 위해 여러 다른 타이밍을 요약할 수 있습니다.

// 不在计时范围内
for ($i = 0; $i start();
for ($i = 0; $i stop();

echo 'Time NS: ', $c->getLastElapsedTime(HRTime\Unit::NANOSECOND), PHP_EOL;
echo 'Time US: ', $c->getLastElapsedTime(HRTime\Unit::MICROSECOND), PHP_EOL;
echo 'Time MS: ', $c->getLastElapsedTime(HRTime\Unit::MILLISECOND), PHP_EOL;
echo 'Time S: ', $c->getLastElapsedTime(HRTime\Unit::SECOND), PHP_EOL;
// Time NS: 7154010
// Time US: 7154.01
// Time MS: 7.15401
// Time S: 0.00715401

echo 'All Time NS: ', $c->getElapsedTime(HRTime\Unit::NANOSECOND), PHP_EOL;
echo 'All Time US: ', $c->getElapsedTime(HRTime\Unit::MICROSECOND), PHP_EOL;
echo 'All Time MS: ', $c->getElapsedTime(HRTime\Unit::MILLISECOND), PHP_EOL;
echo 'All Time S: ', $c->getElapsedTime(HRTime\Unit::SECOND), PHP_EOL;
// All Time NS: 14083898
// All Time US: 14083.898
// All Time MS: 14.083898
// All Time S: 0.014083898

echo 'All Ticks: ', $c->getElapsedTicks(), PHP_EOL;
// All Ticks: 14083898

이 코드에서는 두 개의 타이밍 테스트 코드 사이에 루프 테스트 코드를 삽입했는데, 이는 타이밍 데이터에 포함되지 않습니다. 그런 다음 restart()를 사용하여 새 타이밍을 시작합니다. 마지막에는 getElapsedTime() 및 getElapsedTicks()를 통해 총 타이밍 시간을 얻습니다. 위의 6929888에 이번에는 7154010을 더하면 정확히 14083898이 되는 것을 알 수 있습니다. 타이머에 포함되지 않은 루프 코드의 중간 부분은 총 타이밍 시간에 포함되지 않습니다.

추천 학습: "PHP 비디오 튜토리얼"

总结

是不是很有意思,它的作用真的和我们的体育老师所用的那个秒表一模一样,老师们的秒表也都是可以按多次记录第1名到最后1名的全部跑步成绩,并且最后还有一个总的时间,而在代码中我们也是完全相似的操作。这个扩展对于精细的性能调试非常有用,而且也能够针对一些需要这种高精度时间差的业务进行相关的开发。

测试代码:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202010/source/3.学习PHP中的高精度计时器HRTime扩展.php
参考文档:
https://www.php.net/manual/zh/book.hrtime.php

위 내용은 PHP의 고정밀 타이머 HRTime 확장에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 segmentfault에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
PHP의 지속적인 사용 : 지구력의 이유PHP의 지속적인 사용 : 지구력의 이유Apr 19, 2025 am 12:23 AM

여전히 인기있는 것은 사용 편의성, 유연성 및 강력한 생태계입니다. 1) 사용 편의성과 간단한 구문은 초보자에게 첫 번째 선택입니다. 2) 웹 개발, HTTP 요청 및 데이터베이스와의 우수한 상호 작용과 밀접하게 통합되었습니다. 3) 거대한 생태계는 풍부한 도구와 라이브러리를 제공합니다. 4) 활성 커뮤니티와 오픈 소스 자연은 새로운 요구와 기술 동향에 맞게 조정됩니다.

PHP 및 Python : 유사점과 차이점을 탐구합니다PHP 및 Python : 유사점과 차이점을 탐구합니다Apr 19, 2025 am 12:21 AM

PHP와 Python은 웹 개발, 데이터 처리 및 자동화 작업에 널리 사용되는 고급 프로그래밍 언어입니다. 1.PHP는 종종 동적 웹 사이트 및 컨텐츠 관리 시스템을 구축하는 데 사용되며 Python은 종종 웹 프레임 워크 및 데이터 과학을 구축하는 데 사용됩니다. 2.PHP는 Echo를 사용하여 콘텐츠를 출력하고 Python은 인쇄를 사용합니다. 3. 객체 지향 프로그래밍을 지원하지만 구문과 키워드는 다릅니다. 4. PHP는 약한 유형 변환을 지원하는 반면, 파이썬은 더 엄격합니다. 5. PHP 성능 최적화에는 Opcache 및 비동기 프로그래밍 사용이 포함되며 Python은 Cprofile 및 비동기 프로그래밍을 사용합니다.

PHP와 Python : 다른 패러다임이 설명되었습니다PHP와 Python : 다른 패러다임이 설명되었습니다Apr 18, 2025 am 12:26 AM

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP와 Python : 그들의 역사에 깊은 다이빙PHP와 Python : 그들의 역사에 깊은 다이빙Apr 18, 2025 am 12:25 AM

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP와 Python 중에서 선택 : 가이드PHP와 Python 중에서 선택 : 가이드Apr 18, 2025 am 12:24 AM

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP 및 프레임 워크 : 언어 현대화PHP 및 프레임 워크 : 언어 현대화Apr 18, 2025 am 12:14 AM

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

PHP의 영향 : 웹 개발 및 그 이상PHP의 영향 : 웹 개발 및 그 이상Apr 18, 2025 am 12:10 AM

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?Apr 17, 2025 am 12:25 AM

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경