php生成高精度时间的例子
如果需要使用高于秒的计量精度的时间,例如,要生成一个唯一的ID或者一个函数调用的基准。
使用microtime(true)来以秒和微秒计量当前的时间。
下面的例子使用了microtime(true)来计算要完成1000个正则表达式匹配需要多长时间。
例1: 用microtime()来计时。
$start = microtime(true);
for($i = 0; $i < 1000; $i++) {
preg_match('/age=\d+/',$_SERVER['QUERY_STRING']);
}
$end = microtime(true);
?>
php 5.0.0中增加了对在microtime()中使用可选参数的支持。如果不带参数,或者带有不能转换成true的参数,或者在php的早期版本中,microtime()会返回一个Unix纪元起所经过时间的微秒部分,一个空格和自纪元起所经过的秒数。例如,返回值"0.41644100 1026683258" 意味着自纪元起经过了"1026683258.41644100秒"时间。
包含微秒的时间值对于生成唯一的ID非常有用。只要一个进程不会在一微秒内同时生成一个以上的ID,就能保证用包含微秒的时间值与当前进程的ID组成一个唯一的ID值。
再来看一个例子:使用microtime()(返回的字符串格式)生成了这样一个ID。
例2:用microtime()生成一个ID
list($microseconds,$seconds) = explode(' ',microtime());
$id = $seconds.$microseconds.getmypid();
?>
注意:
例2在多线程的系统中并不十分可靠,因为存一个非难(但极小)的概率,同一个进程的两个线程会在同一微秒内调用microtime()。
您可能感兴趣的文章:
php生成高精度时间的例子
php难不难
php中浮点数计算问题整理
php代码生成器好用吗
php生成随机数的例子
php浮点数精度用法分析
PHP浮点精度问题
PHP图片裁剪函数(图像不变形)
PHP浮点数精度丢失问题解决方案
MySQL数据类型总结 mysql常用数据类型