您现在的位置: 万盛学电脑网 >> 程序编程 >> 网络编程 >> php编程 >> 正文

9个实用的PHP函数

作者:佚名    责任编辑:admin    更新时间:2022-06-22

  即使使用 PHP 多年,也会偶然发现一些未曾了解的函数和功能。其中有些是非常有用的,但没有得到充分利用。并不是所有人都会从头到尾一页一页地阅读手册和函数参考!

  1、任意参数数目的函数

  你可能已经知道,PHP 允许定义可选参数的函数。但也有完全允许任意数目的函数参数的方法。以下是可选参数的例子:

  // function with 2 optional arguments

  function foo($arg1 = '', $arg2 = '') {

  echo "arg1: $arg1n";

  echo "arg2: $arg2n";

  }

  foo('hello','world');

  /* prints:

  arg1: hello

  arg2: world

  */

  foo();

  /* prints:

  arg1:

  arg2:

  */

  现在让我们看看如何建立能够接受任何参数数目的函数。这一次需要使用 func_get_args() 函数:

  // yes, the argument list can be empty

  function foo() {

  // returns an array of all passed arguments

  $args = func_get_args();

  foreach ($args as $k => $v) {

  echo "arg".($k+1).": $vn";

  }

  }

  foo();

  /* prints nothing */

  foo('hello');

  /* prints

  arg1: hello

  */

  foo('hello', 'world', 'again');

  /* prints

  arg1: hello

  arg2: world

  arg3: again

  */

  2、使用 Glob() 查找文件

  许多 PHP 函数具有长描述性的名称。然而可能会很难说出 glob() 函数能做的事情,除非你已经通过多次使用并熟悉了它。可以把它看作是比 scandir() 函数更强大的版本,可以按照某种模式搜索文件。

  // get all php files

  $files = glob('*.php');

  print_r($files);

  /* output looks like:

  Array

  (

  [0] => phptest.php

  [1] => pi.php

  [2] => post_output.php

  [3] => test.php

  )

  */

  你可以像这样获得多个文件:

  // get all php files AND txt files

  $files = glob('*.{php,txt}', GLOB_BRACE);

  print_r($files);

  /* output looks like:

  Array

  (

  [0] => phptest.php

  [1] => pi.php

  [2] => post_output.php

  [3] => test.php

  [4] => log.txt

  [5] => test.txt

  )

  */

  请注意,这些文件其实是可以返回一个路径,这取决于查询条件:

  $files = glob('../images/a*.jpg');

  print_r($files);

  /* output looks like:

  Array

  (

  [0] => ../images/apple.jpg

  [1] => ../images/art.jpg

  )

  */

  如果你想获得每个文件的完整路径,你可以调用 realpath() 函数:

  $files = glob('../images/a*.jpg');

  // applies the function to each array element

  $files = array_map('realpath',$files);

  print_r($files);

  /* output looks like:

  Array

  (

  [0] => C:wampwwwimagesapple.jpg

  [1] => C:wampwwwimagesart.jpg

  )

  */

  3、内存使用信息

  通过侦测脚本的内存使用情况,有利于代码的优化。PHP 提供了一个垃圾收集器和一个非常复杂的内存管理器。脚本执行时所使用的内存量,有升有跌。为了得到当前的内存使用情况,我们可以使用 memory_get_usage() 函数。如果需要获得任意时间点的最高内存使用量,则可以使用 memory_limit() 函数。

  echo "Initial: ".memory_get_usage()." bytes n";

  /* prints

  Initial: 361400 bytes

  */

  // let's use up some memory

  for ($i = 0; $i < 100000; $i++) {

  $array []= md5($i);

  }

  // let's remove half of the array

  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";

  /* prints

  Peak: 13687072 bytes

  */

  4、CPU 使用信息

  为此,我们要利用 getrusage() 函数。请记住这个函数不适用于 Windows 平台。

  print_r(getrusage());

  /* prints

  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

  )

  */

  这可能看起来有点神秘,除非你已经有系统管理员权限。以下是每个值的具体说明(你不需要记住这些):

  ru_oublock: block output operations

  ru_inblock: block input operations

  ru_msgsnd: messages sent

  ru_msgrcv: messages received

  ru_maxrss: maximum resident set size

  ru_ixrss: integral shared memory size

  ru_idrss: integral unshared data size

  ru_minflt: page reclaims

  ru_majflt: page faults

  ru_nsignals: signals received

  ru_nvcsw: voluntary context switches

  ru_nivcsw: involuntary context switches

  ru_nswap: swaps

  ru_utime.tv_usec: user time used (microseconds)

  ru_utime.tv_sec: user time used (seconds)

  ru_stime.tv_usec: system time used (microseconds)

  ru_stime.tv_sec: system time used (seconds)

  要知道脚本消耗多少 CPU 功率,我们需要看看 ‘user time’ 和 ’system time’ 两个参数的值。秒和微秒部分默认是单独提供的。你可以除以 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);

  echo "System time: ".

  ($data['ru_stime.tv_sec'] +

  $data['ru_stime.tv_usec'] / 1000000);

  /* prints

  User time: 0.011552

  System time: 0

  */

  尽管脚本运行用了大约 3 秒钟,CPU 使用率却非常非常低。因为在睡眠运行的过程中,该脚本实际上不消耗 CPU 资源。还有许多其他的任务,可能需要一段时间,但不占用类似等待磁盘操作等 CPU 时间。因此正如你所看到的,CPU 使用率和运行时间的实际长度并不总是相同的。下面是一个例子:

  // 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);

  echo "System time: ".

  ($data['ru_stime.tv_sec'] +

  $data['ru_stime.tv_usec'] / 1000000);

  /* prints

  User time: 1.424592

  System time: 0.004204

  */

  这花了大约 1.4 秒的 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);

  echo "System time: ".

  ($data['ru_stime.tv_sec'] +