• 实用的PHP功能详解(一)_php glob()用法


    一、使用glob()查找文件 

    大部分PHP函数的函数名从字面上都可以理解其用途,但是当你看到 glob() 的时候,你也许并不知道这是用来做什么的,其实glob()和scandir() 一样,可以用来查找文件,请看下面的用法:

    // 取得所有的后缀为PHP的文件  
    $files = glob(‘*.php’);  
    print_r($files);  
    /* 输出: 
    Array 
    ( 
    [0] => phptest.php 
    [1] => pi.php 
    [2] => post_output.php 
    [3] => test.php 
    ) 
    */  

    二、获取内存使用情况信息 

    PHP的内存回收机制已经非常强大,你也可以使用PHP脚本获取当前内存的使用情况,调用memory_get_usage() 函数获取当期内存使用情况,调用memory_get_peak_usage() 函数获取内存使用的峰值。参考代码如下: 

    echo “Initial: “.memory_get_usage().” bytes 
    ”;  
    /* 输出 
    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 
    ”;  
    /* prints 
    Final: 885912 bytes 
    */  
    echo “Peak: “.memory_get_peak_usage().” bytes 
    ”;  
    /* 输出峰值 
    Peak: 13687072 bytes 
    */  

    三、获取CPU使用情况信息

    获取了内存使用情况,也可以使用PHP的 getrusage()获取CPU使用情况,该方法在windows下不可用。

    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: 发送的message
    • ru_msgrcv: 收到的message
    • ru_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万,并把它添加到秒的值后,可以得到有小数部分的秒数。
    // sleep for 3 seconds (non-busy)  
    sleep(3);  
    $data = getrusage();  
    echo “User time: “.  
    ($data['ru_utime.tv_sec'] +  
    $data['ru_utime.tv_usec'] / 1000000);  
    echoSystem time: “.  
    ($data['ru_stime.tv_sec'] +  
    $data['ru_stime.tv_usec'] / 1000000);  
    /* 输出 
    User time: 0.011552 
    System time: 0 
    */  

    sleep是不占用系统时间的,我们可以来看下面的一个例子: 

    // loop 10 million times (busy)  
    for($i=0;$i<10000000;$i++) {  
    }  
    $data = getrusage();  
    echo “User time: “.  
    ($data['ru_utime.tv_sec'] +  
    $data['ru_utime.tv_usec'] / 1000000);  
    echoSystem time: “.  
    ($data['ru_stime.tv_sec'] +  
    $data['ru_stime.tv_usec'] / 1000000);  
    /* 输出 
    User time: 1.424592 
    System time: 0.004204 
    */  
    这花了大约14秒的CPU时间,几乎所有的都是用户的时间,因为没有系统调用。 
    系统时间是CPU花费在系统调用上的上执行内核指令的时间。下面是一个例子:
    $start = microtime(true);  
    // keep calling microtime for about 3 seconds  
    while(microtime(true) – $start < 3) {  
    }  
    $data = getrusage();  
    echo “User time: “.  
    ($data['ru_utime.tv_sec'] +  
    $data['ru_utime.tv_usec'] / 1000000);  
    echoSystem time: “.  
    ($data['ru_stime.tv_sec'] +  
    $data['ru_stime.tv_usec'] / 1000000);  
    /* prints 
    User time: 1.088171 
    System time: 1.675315 
    */  

    我们可以看到上面这个例子更耗CPU。

    四、传递任意数量的函数参数 

    我们在.NET或者JAVA编程中,一般函数参数个数都是固定的,但是PHP允许你使用任意个数的参数。下面这个示例向你展示了PHP函数的默认参数: 

    // 两个默认参数的函数  
    function foo($arg1 = ”, $arg2 = ”) {  
    echo “arg1: $arg1
    ”;  
    echo “arg2: $arg2
    ”;  
    }  
    foo(‘hello’,'world’);  
    /* 输出: 
    arg1: hello 
    arg2: world 
    */  
    foo();  
    /* 输出: 
    arg1: 
    arg2: 
    */  
    下面这个示例是PHP的不定参数用法,其使用到了 func_get_args()方法:  
    // 是的,形参列表为空  
    function foo() {  
    // 取得所有的传入参数的数组  
    $args = func_get_args();  
    foreach ($args as $k => $v) {  
    echo “arg”.($k+1).”: $v
    ”;  
    }  
    }  
    foo();  
    /* 什么也不会输出 */  
    foo(‘hello’);  
    /* 输出 
    arg1: hello 
    */  
    foo(‘hello’, ‘world’, ‘again’);  
    /* 输出 
    arg1: hello 
    arg2: world 
    arg3: again 
    */  
  • 相关阅读:
    polarsignals frostdb golang嵌入式列存
    fgprof golang profiler 支持on cpu 以及off cpu
    windows jenkins openssh 集成问题
    buf 工具的一些概念
    nginx njs 0.7.7发布
    nginx proxy_pass 包含路径问题
    基于iap 的安全控制
    frida 动态检测工具集
    buf buf.work.yaml 一个好用的功能
    一些不错的nginx 开发资料
  • 原文地址:https://www.cnblogs.com/auto6s/p/3400070.html
Copyright © 2020-2023  润新知