2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > PHP记录代码运行时间

PHP记录代码运行时间

时间:2018-08-15 19:13:55

相关推荐

PHP记录代码运行时间

后端开发|php教程

PHP记录代码运行时间

后端开发-php教程

代码运行时间测量

贴吧首页源码,ubuntu汉字输入,tomcat8安装和配置,300元爬虫视频,PHP制作网页验证码,seo转换度量lzw

一般在要求性能的代码中, 会加入测试代码进行计算。

壁纸软件 源码,ubuntu纯命令联网,tomcat6 关闭日志,六足爬虫,php开发如何学习技术,湘阴SEOlzw

不过每次都要写microtime, end – start 未必太麻烦了, 所以简单的写了一个类去搞。

大麦户php网站源码,vscode引入字体样式,ubuntu中$是,tomcat 显示被占用,sqlite修改一条记录,爬虫做好的脚本安卓怎么运行,php if判断大于,长沙专业的seo排名,利于优化的网站模板,怎么制作织梦手机模板lzw

代码

class TimeCost{ private $cost = array(); private $record = array(); private $scale = 6; public function __construct($scale = 6) { $this->cost = array(); $this->record = array(); $this->scale = $scale; } public function __toString() { return $this->getString(); } /*** start to cal time.** @param mixed $key*/ public function addCost($key) { $this->cost[$key] = microtime(true); } /*** stop to cal time.** @param mixed $key*/ public function closeCost($key) { $cost = bcsub(microtime(true), $this->cost[$key], $this->scale); if (in_array($key, array_keys($this->record))) { $this->record[$key] = bcadd($cost, $this->record[$key], $this->scale); } else { $this->record[$key] = $cost; } return $cost; } public function getString($key = null) { if ($key) { return "{$key}[{$this->record[$key]}]"; } $str = \; foreach ($this->record as $k => $v) { $str .= "{$k}[{$v}]"; } return $str; }}

用法

$obj = new TimeCost();$token = est_a;$obj->addCost($token);some_code();$obj->closeCost($token);$reslut = $obj->getString($token);

说明

时间精度: 默认是保留了6位, 已经足够了, 想要更高精度, 可以在new对象的时候指定$scale参数

token: token是为了表示某段代码, 对应的结果会以key(token), value的形式写入到record数组中。

所以用一个token多次进行addCost和closeClost的结果会进行累积。

getString: 传递token则返回token对应的结果, 默认会将record中的所有结果拼接返回。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。