找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 387|回复: 0
打印 上一主题 下一主题

php统计时间和内存使用情况示例分享

[复制链接]

2560

主题

2560

帖子

7622

积分

论坛元老

Rank: 8Rank: 8

积分
7622
跳转到指定楼层
楼主
发表于 2018-2-14 05:59:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            [U]复制代码[/U] 代码如下:
/**
* 记录和统计时间(微秒)和内存使用情况
* 使用方法:
*
* G('begin'); // 记录开始标记位
* // ... 区间运行代码
* G('end'); // 记录结束标签位
* echo G('begin','end',6); // 统计区间运行时间 精确到小数后6位
* echo G('begin','end','m'); // 统计区间内存使用情况
* 如果end标记位没有定义,则会自动以当前作为标记位
* 其中统计内存使用需要 MEMORY_LIMIT_ON 常量为true才有效
*
* @param string $start 开始标签
* @param string $end 结束标签
* @param integer|string $dec 小数位或者m
* @return mixed
*/
function G($start,$end='',$dec=4) {
    static $_info       =   array();
    static $_mem        =   array();
    if(is_float($end)) { // 记录时间
        $_info[$start]  =   $end;
    }elseif(!empty($end)){ // 统计时间和内存使用
        if(!isset($_info[$end])) $_info[$end]       =  microtime(TRUE);
        if(MEMORY_LIMIT_ON && $dec=='m'){
            if(!isset($_mem[$end])) $_mem[$end]     =  memory_get_usage();
            return number_format(($_mem[$end]-$_mem[$start])/1024);         
        }else{
            return number_format(($_info[$end]-$_info[$start]),$dec);
        }      
    }else{ // 记录时间和内存使用
        $_info[$start]  =  microtime(TRUE);
        if(MEMORY_LIMIT_ON) $_mem[$start]           =  memory_get_usage();
    }
}
            
            
您可能感兴趣的文章:
  • PHP 内存缓存加速功能memcached安装与用法
  • PHP数组内存耗用太多问题的解决方法
  • 访问php时提示内存位置访问无效的解决办法和思路分析
  • 采用PHP函数memory_get_usage获取PHP内存清耗量的方法
  • PHP中使用unset销毁变量并内存释放问题
  • phpExcel导出大量数据出现内存溢出错误的解决方法
  • 关于PHP内存溢出问题的解决方法
  • 解析PHP中的内存管理,PHP动态分配和释放内存
  • 解析PHP中的unset究竟会不会释放内存
  • php出现内存位置访问无效错误问题解决方法
  • PHP脚本内存泄露导致Apache频繁宕机解决方法
  • PHP通过内置函数memory_get_usage()获取内存使用情况
  • php查询mysql大量数据造成内存不足的解决方法
  • php实现读取内存顺序号
  • 解决PHP里大量数据循环时内存耗尽的方法
  • PHP内存使用情况如何获取
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端