목차
Clock Beat
시스템 시계 틱 정보 가져오기 Ticks
타이머 기능
总结
백엔드 개발 PHP 튜토리얼 PHP의 고정밀 타이머 HRTime 확장에 대한 자세한 설명

PHP의 고정밀 타이머 HRTime 확장에 대한 자세한 설명

Jul 10, 2021 pm 03:12 PM
php

학교 체육 시험 때 선생님이 가져온 스톱워치를 아직도 기억하시나요? 총소리가 들리면 우리는 달리기 시작했고, 결승선을 통과하면 교사가 버튼을 눌러 결과를 기록했습니다. 오늘 우리가 배울 내용은 사실 이번 스포츠 테스트의 스톱워치와 유사한 기능적 확장입니다. 바로 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 < 1024*1024; $i++);
echo &#39;isRunning: &#39;, $c->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 < 1024*1024; $i++);

$c->start();
for ($i = 0; $i < 1024*1024; $i++);
$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: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP 데이터베이스 작업 CakePHP 데이터베이스 작업 Sep 10, 2024 pm 05:25 PM

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

cakephp4에서 날짜와 시간을 다루기 위해 사용 가능한 FrozenTime 클래스를 활용하겠습니다.

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

파일 업로드 작업을 위해 양식 도우미를 사용할 것입니다. 다음은 파일 업로드의 예입니다.

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

CakePHP 로깅 CakePHP 로깅 Sep 10, 2024 pm 05:26 PM

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

See all articles