php比较好用的几种函数及方法

    技术2022-05-20  43

    1.数组相加:

    直接$arr1+$arr2

    2.打印堆栈函数

    PHP debug_backtrace() 函数生成一个 backtrace。

    该函数返回一个关联数组。下面是可能返回的元素:

    3. pack()  Pack() 能将md5()返回的32位16进制字符串转换为16位的二进制字符串,可以节省存储空间。 

     

    4. sys_getloadavg()  sys_getloadavt()可以获得系 统负载情况。该函数返回一个包含三个元素的数组,每个元素分别代表系统再过去的1、5和15分钟内的平均负载。  与其让服务器因负 载过高而宕掉,不如在系统负载很高时主动die掉一个脚本,sys_getloadavg()就是用来帮你实现这个功能的。 不过很遗憾,该函数在windows下无效。

     

    5. func_get_args()

    function foo() {        // 取得所有的传入参数的数组      $args = func_get_args();        foreach ( $args as $k => $v ) {          echo "arg" .( $k +1). ": $v/n" ;      }   } 6.使用 Glob() 查找文件 // 取PHP文件和TXT文件 $files = glob ( '*.{php,txt}' , GLOB_BRACE);   print_r( $files ); /* 输出: Array (      [0] => phptest.php      [1] => pi.php      [2] => post_output.php      [3] => test.php      [4] => log.txt      [5] => test.txt ) */ 7.内存使用信息

    观察你程序的内存使用能够让你更好的优化你的代码。

    PHP 是有垃圾回收机制的,而且有一套很复杂的内存管理机制。你可以知道你的脚本所使用的内存情况。要知道当前内存使用情况,你可以使用?memory_get_usage() 函数,如果你想知道使用内存的峰值,你可以调用memory_get_peak_usage() 函数。

    echo "Initial: ".memory_get_usage()." bytes /n"; /* 输出 Initial: 361400 bytes */ // 使用内存 for ($i = 0; $i < 100000; $i++) { $array []= md5($i); } // 删除一半的内存 for ($i = 0; $i < 100000; $i++) { unset($array[$i]); } echo "Final: ".memory_get_usage()." bytes /n"; /* prints Final: 885912 bytes */ echo "Peak: ".memory_get_peak_usage()." bytes /n"; /* 输出峰值 Peak: 13687072 bytes */

    8.CPU使用信息

    print_r(getrusage()); /* 输出 Array ( [ru_oublock] => 0 [ru_inblock] => 0 [ru_msgsnd] => 2 [ru_msgrcv] => 3 [ru_maxrss] => 12692 [ru_ixrss] => 764 [ru_idrss] => 3864 [ru_minflt] => 94 [ru_majflt] => 0 [ru_nsignals] => 1 [ru_nvcsw] => 67 [ru_nivcsw] => 4 [ru_nswap] => 0 [ru_utime.tv_usec] => 0 [ru_utime.tv_sec] => 0 [ru_stime.tv_usec] => 6269 [ru_stime.tv_sec] => 0 ) */

    这个结构看上出很晦涩,除非你对CPU很了解。下面一些解释:

    ru_oublock: 块输出操作ru_inblock: 块输入操作ru_msgsnd: 发送的messageru_msgrcv: 收到的messageru_maxrss: 最大驻留集大小ru_ixrss: 全部共享内存大小ru_idrss:全部非共享内存大小ru_minflt: 页回收ru_majflt: 页失效ru_nsignals: 收到的信号ru_nvcsw: 主动上下文切换ru_nivcsw: 被动上下文切换ru_nswap: 交换区ru_utime.tv_usec: 用户态时间 (microseconds)ru_utime.tv_sec: 用户态时间(seconds)ru_stime.tv_usec: 系统内核时间 (microseconds)ru_stime.tv_sec: 系统内核时间?(seconds)

    要看到你的脚本消耗了多少CPU,我们需要看看“用户态的时间”和“系统内核时间”的值。秒和微秒部分是分别提供的,您可以把微秒值除以100万,并把它添加到秒的值后,可以得到有小数部分的秒数。

     

    8.字符串压缩

    当我们说到压缩,我们可能会想到文件压缩,其实,字符串也是可以压缩的。PHP提供了?gzcompress() 和 gzuncompress() 函数:

    $string = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ut elit id mi ultricies adipiscing. Nulla facilisi. Praesent pulvinar, sapien vel feugiat vestibulum, nulla dui pretium orci, non ultricies elit lacus quis ante. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam pretium ullamcorper urna quis iaculis. Etiam ac massa sed turpis tempor luctus. Curabitur sed nibh eu elit mollis congue. Praesent ipsum diam, consectetur vitae ornare a, aliquam a nunc. In id magna pellentesque tellus posuere adipiscing. Sed non mi metus, at lacinia augue. Sed magna nisi, ornare in mollis in, mollis sed nunc. Etiam at justo in leo congue mollis. Nullam in neque eget metus hendrerit scelerisque eu non enim. Ut malesuada lacus eu nulla bibendum id euismod urna sodales. "; $compressed = gzcompress($string); echo "Original size: ". strlen($string)."/n"; /* 输出原始大小 Original size: 800 */ echo "Compressed size: ". strlen($compressed)."/n"; /* 输出压缩后的大小 Compressed size: 418 */ // 解压缩 $original = gzuncompress($compressed);

    几乎有50% 压缩比率。同时,你还可以使用?gzencode() 和 gzdecode() 函数来压缩,只不用其用了不同的压缩算法。

     

    9.注册停止 函数

    有一个函数叫做?register_shutdown_function() ,可以让你在整个脚本停时前运行代码。让我们看下面的一个示例:

    $start_time = microtime(true); // do some stuff // ... // display how long the script took echo "execution took: ". (microtime(true) - $start_time). " seconds.";

    上面这个示例只不过是用来计算某个函数运行的时间。然后,如果你在函数中间调用?exit() 函数,那么你的最后的代码将不会被运行到。并且,如果该脚本在浏览器终止(用户按停止按钮),其也无法被运行。

    而当我们使用了register_shutdown_function()后,你的程序就算是在脚本被停止后也会被运行:

    $start_time = microtime(true); register_shutdown_function('my_shutdown'); // do some stuff // ... function my_shutdown() { global $start_time; echo "execution took: ". (microtime(true) - $start_time). " seconds."; }

     

    很大一部分转载自陈浩的博客 原地址  http://coolshell.cn/articles/2394.html#more-2394


    最新回复(0)