0

0

毫秒级时间获取_PHP microtime使用技巧【操作】

雪夜

雪夜

发布时间:2026-03-11 21:34:33

|

493人浏览过

|

来源于php中文网

原创

microtime() 返回值类型取决于参数:不传或传 false 时返回字符串,传 true 时返回浮点数;直接用 microtime() 做减法易因字符串拼接出错,应统一用 microtime(true) 计算耗时。

毫秒级时间获取_php microtime使用技巧【操作】

microtime() 返回值到底是字符串还是浮点数?

取决于是否传 true:不传或传 false,返回形如 "0.12345678 1712345678" 的字符串;传 true 才返回浮点数(单位秒,含微秒精度)。很多同学直接用 microtime() 做减法,结果得到字符串拼接而非数值差——这是最常踩的类型坑。

实操建议:

  • 要计算耗时,必须统一用 microtime(true) 开始和结束,再相减
  • 别用 list($usec, $sec) = explode(' ', microtime()) 手动拆——PHP 7.4+ 已支持 microtime(false) 配合 sscanf,但没必要,true 更直白
  • 注意浮点精度:PHP 默认 float 是双精度,毫秒级差值误差在 1e-15 秒量级,对业务完全够用,不用上 GMPBCMath

为什么 microtime(true) 在 CLI 和 FPM 下表现一致?

因为 microtime() 底层调用的是系统 gettimeofday()(Linux/macOS)或 QueryPerformanceCounter()(Windows),与 SAPI 无关。但要注意:CLI 脚本生命周期短,FPM 请求可能被 opcache 缓存、或受 fastcgi_finish_request() 干扰——不是 microtime 本身问题,而是你测的位置错了。

常见错误现象:

立即学习PHP免费学习笔记(深入)”;

一帧秒创
一帧秒创

基于秒创AIGC引擎的AI内容生成平台,图文转视频,无需剪辑,一键成片,零门槛创作视频。

下载
  • fastcgi_finish_request() 后调用 microtime(true),误以为是“响应耗时”,其实只是脚本剩余执行时间
  • FPM 下开启 opcache.enable_cli=1 测 CLI 性能,结果比实际高——opcode 缓存让初始化变快,但掩盖了真实 autoload 开销
  • $_SERVER['REQUEST_TIME_FLOAT'] 当起点,它只精确到秒级(PHP 5.4+ 才有小数),比 microtime(true) 开始晚几十微秒,不适合亚毫秒级测量

替代方案:hrtime() 比 microtime() 更准吗?

是的,hrtime()(PHP 7.3+)返回纳秒级整数数组,不受系统时钟调整影响(microtime 可能因 NTP 校正跳变),且无浮点舍入误差。但它不是万能的——仅适合短时高精度测量,比如函数级 benchmark,不适合记录日志时间戳(因为不能直接转成可读日期)。

使用场景对比:

  • 测单个函数执行:优先用 hrtime(true),返回 int 纳秒值,做减法零误差
  • 记录请求开始/结束时间并存库:仍用 microtime(true),方便转 date('Y-m-d H:i:s.u')
  • 跨进程或分布式追踪:别依赖本地时钟,用 Trace-ID + span timestamp 配合外部时间源(如 NTP 同步后的 clock_gettime(CLOCK_REALTIME)

Windows 下 microtime() 为什么有时卡住 15ms?

老版本 Windows(Win7/2008 及之前)默认系统定时器精度只有 15.625ms,microtime() 会受此限制,连续调用可能返回相同值。PHP 自身无法绕过,得靠系统级调整。

解决办法很直接:

  • 升级到 Windows 10/2016+,默认精度已提升至 1–2ms
  • 若必须用旧系统,运行命令 powercfg /energy 检查是否启用高性能电源计划(平衡/节能模式会锁低精度)
  • 终极手段:用 timeBeginPeriod(1)(需 winmm.dll),但 PHP 不内置封装,得写扩展或调用 exec() ——不推荐,副作用大

真正容易被忽略的是:这个精度问题只影响「连续高频采样」,比如循环里每轮都 microtime(true),而 Web 请求这种单次测量基本感知不到。别一看到 Windows 就慌,先看你的用法是不是真踩中了那个 15ms 坑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

405

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.10.07

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

595

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

106

2025.10.23

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.3万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号