使用ltrace工具跟踪PHP库函数调用的方法

 更新时间:2016年04月25日 09:35:46   作者:z32556601  
这篇文章主要介绍了使用ltrace工具跟踪PHP库函数调用的方法,结合实例形式分析了ltrace工具用来跟踪PHP库函数运行时间的相关技巧,需要的朋友可以参考下

本文实例讲述了使用ltrace工具跟踪PHP库函数调用的方法。分享给大家供大家参考,具体如下:

可能大家已经很熟悉使用strace来跟踪系统调用,今天介绍一个跟踪库函数的利器ltrace

比如我有这么一段PHP代码

test.php:

<?php
 $y = '1380';
 $arr = array();
 for($i = 0; $i < 2000; $i ++){
   $arr[] = "{$i}"; //故意用引号包起来设成字符串
 }
 for($i = 0; $i < 2000; $i ++){
   if(!in_array($y, $arr)) continue;
 }
?>

ltrace -c /usr/local/php/bin/php test.php (-c表示汇总)

会看到输出如下:

% time   seconds usecs/call   calls   function
------ ----------- ----------- --------- --------------------
95.02  7.417240     368   20146 strtol
2.15  7.160390     413   17316 memcpy
1.63  5.522641     240   22966 free
 0.67  2.275374   2275374     1 curl_global_cleanup
 0.54  2.235466     617   3618 __ctype_tolower_loc
 0.16  2.123547    1194   1778 strrchr
 0.17  1.532224     67   22836 malloc
 0.29  0.382083     67   5678 strlen

可以看到 strtol几乎用去了执行时间的95.02%,瓶颈就找出来了。及PHP会在in_array()测试时试图将字符串行数字转换为long,这会耗费大量时间。所以只要将字符串都转换为整形即可大幅度提高效率。

ltrace真心是个好工具

希望本文所述对大家PHP程序设计有所帮助。

相关文章

  • PHP简单选择排序算法实例

    PHP简单选择排序算法实例

    这篇文章主要介绍了PHP简单选择排序算法实例,本文直接给出实现代码,并以类的方式实现,需要的朋友可以参考下
    2015-01-01
  • php中debug_backtrace、debug_print_backtrace和匿名函数用法实例

    php中debug_backtrace、debug_print_backtrace和匿名函数用法实例

    这篇文章主要介绍了php中debug_backtrace、debug_print_backtrace和匿名函数用法,以实例形式分析了debug_backtrace和debug_print_backtrace函数在调试过程中的作用,并分析了PHP5.3新增匿名函数的用法,需要的朋友可以参考下
    2014-12-12
  • PHP实现自定义文件缓存的方法

    PHP实现自定义文件缓存的方法

    这篇文章主要介绍了PHP是如何实现自定义文件缓存的方法的,文中通过代码示例给大家介绍了两个方法,具有一定的参考价值,需要的朋友可以参考下
    2023-10-10
  • 解析PHP提交后跳转

    解析PHP提交后跳转

    本篇文章是对PHP提交后跳转进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • php实现zip文件解压操作

    php实现zip文件解压操作

    这篇文章主要介绍了php实现zip文件解压操作的函数代码,每一条函数代码都有对应的文字注释,需要的朋友可以参考下
    2015-11-11
  • PHP经典设计模式之依赖注入定义与用法详解

    PHP经典设计模式之依赖注入定义与用法详解

    这篇文章主要介绍了PHP经典设计模式之依赖注入,结合实例形式分析了php依赖注入的定义、原理与用法,需要的朋友可以参考下
    2019-05-05
  • php简单实现多语言切换的方法

    php简单实现多语言切换的方法

    这篇文章主要介绍了php简单实现多语言切换的方法,涉及php字符串、数组结合session操作实现多语言切换的相关技巧,需要的朋友可以参考下
    2016-05-05
  • PHP的Yii框架中Model模型的学习教程

    PHP的Yii框架中Model模型的学习教程

    这篇文章主要介绍了PHP的Yii框架中Model模型的学习教程,Yii框架本身就显庞大,所以模型类也就更加需要很好的编写维护,需要的朋友可以参考下
    2016-03-03
  • PHP运行模式汇总

    PHP运行模式汇总

    本文给大家汇总介绍了php的5种运行模式,并进行了简单的对比,非常的细致全面,希望对大家学习使用php能够有所帮助
    2016-11-11
  • php中0,null,empty,空,false,字符串关系的详细介绍

    php中0,null,empty,空,false,字符串关系的详细介绍

    本篇文章是对php中0,null,empty,空,false,字符串关系进行了详细的分析介绍,需要的朋友参考下
    2013-06-06

最新评论