以下九种PHP一个非常有用的功能。我不知道你还没有使用?1. 的功能,你可能知道的参数,任意数量PHP我同意你定义一个函数默认参数。
但你可能并不知道PHP还同意你定义一个全然随意的參数的函数以下是一个演示样例向你展示了默认...
1. 函数的随意数目的參数
你可能知道PHP同意你定义一个默认參数的函数。但你可能并不知道PHP还同意你定义一个全然随意的參数的函数
以下是一个演示样例向你展示了默认參数的函数:
function foo($arg1 = '', $arg2 = '') { echo "arg1: $arg1\n";
echo "arg2: $arg2\n"; } foo('hello','world');
/* 输出:
arg1: hello
arg2: world
*/ foo();
/* 输出:
arg1:
arg2:
*/
如今我们来看一看一个不定參数的函数,其使用到了?func_get_args()方法:
// 是的,形參列表为空
function foo() { // 取得全部的传入參数的数组
$args = func_get_args(); foreach ($args as $k => $v) {
echo "arg".($k+1).": $v\n";
} } foo();
/* 什么也不会输出 */ foo('hello');
/* 输出
arg1: hello
*/ foo('hello', 'world', 'again');
/* 输出
arg1: hello
arg2: world
arg3: again
*/
2.使用 Glob() 查找文件
非常多PHP的函数都有一个比較长的自解释的函数名,可是,当你看到?glob()的时候。你可能并不知道这个函数是用来干什么的。除非你对它已经非常熟悉了。
你能够觉得这个函数就好?scandir()一样,其能够用来查找文件。
// 取得全部的后缀为PHP的文件
$files = glob('*.php'); print_r($files);
/* 输出:
Array
(
[0] => phptest.php
[1] => pi.php
[2] => post_output.php
[3] => test.php
)
*/
你还能够查找多种后缀名 // 取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
)
*/
//你还能够加上路径: $files = glob('../images/a*.jpg'); print_r($files);
/* 输出:
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:\wamp\www\images\apple.jpg
[1] => C:\wamp\www\images\art.jpg
)
*/
3.内存使用信息
观察你程序的内存使用可以让你更好的优化你的代码。
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
*/
4.CPU使用信息
使用?
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);
echo "System 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);
echo "System 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);
echo "System time: ".
($data['ru_stime.tv_sec'] +
$data['ru_stime.tv_usec'] / 1000000); /* prints
User time: 1.088171
System time: 1.675315
*/
我们能够看到上面这个样例更耗CPU。
5.系统常量
PHP 提供很实用的系统常量能够让你得到当前的行号
(__LINE__),文件 (__FILE__),文件夹 (__DIR__),函数名 (__FUNCTION__),类名(__CLASS__),方法名(__METHOD__) 和名字空间 (__NAMESPACE__),非常像C语言。
我们能够以为这些东西主要是用于调试,当也不一定,比方我们能够在include其他文件的时候使用?
__FILE__ (当然,你也能够在 PHP 5.3以后使用 __DIR__ ),以下是一个样例。
/ this is relative to the loaded script's path
// it may cause problems when running scripts from different directories
require_once('config/database.php'); // this is always relative to this file's path
// no matter where it was included from
require_once(dirname(__FILE__) . '/config/database.php');
//以下是使用 __LINE__ 来输出一些debug的信息,这样有助于你调试程序: // some code
// ...
my_debug("some debug message", __LINE__);
/* 输出
Line 4: some debug message
*/ // some more code
// ...
my_debug("another debug message", __LINE__);
/* 输出
Line 11: another debug message
*/ function my_debug($msg, $line) {
echo "Line $line: $msg\n";
}
6.生成唯一的ID
有非常多人使用 md5() 来生成一个唯一的ID,例如以下所看到的:
// generate unique string
echo md5(time() . mt_rand(1,1000000));
事实上,PHP中有一个叫?uniqid()的函数是专门用来干这个的: // generate unique string
echo uniqid();
/* 输出
4bd67c947233e
*/ // generate another unique string
echo uniqid();
/* 输出
4bd67c9472340
*/
可能你会注意到生成出来的ID前几位是一样的,这是由于生成器依赖于系统的时间,这事实上是一个非常不错的功能,由于你是非常easy为你的这些ID排序的。这点MD5是做不到的。 你还能够加上前缀避免重名: // 前缀
echo uniqid('foo_');
/* 输出
foo_4bd67d6cd8b8f
*/ // 有很多其它的熵
echo uniqid('',true);
/* 输出
4bd67d6cd8b926.12135106
*/ // 都有
echo uniqid('bar_',true);
/* 输出
bar_4bd67da367b650.43684647
*/
并且,生成出来的ID会比MD5生成的要短。这会让你节省非常多空间。
7.序列化
你是否会把一个比較复杂的数据结构存到数据库或是文件里?你并不须要自己去写自己的算法。
PHP早已为你做好了,其提供了两个函数:?
// 一个复杂的数组
$myvar = array(
'hello',
42,
array(1,'two'),
'apple'
); // 序列化
$string = serialize($myvar); echo $string;
/* 输出
a:4:{i:0;s:5:"hello";i:1;i:42;i:2;a:2:{i:0;i:1;i:1;s:3:"two";}i:3;s:5:"apple";}
*/ // 反序例化
$newvar = unserialize($string); print_r($newvar);
/* 输出
Array
(
[0] => hello
[1] => 42
[2] => Array
(
[0] => 1
[1] => two
) [3] => apple
)
*/
这是PHP的原生函数,然而在今天JSON越来越流行。所以在PHP5.2以后,PHP開始支持JSON。你能够使用 json_encode() 和 json_decode() 函数 // a complex array
$myvar = array(
'hello',
42,
array(1,'two'),
'apple'
); // convert to a string
$string = json_encode($myvar); echo $string;
/* prints
["hello",42,[1,"two"],"apple"]
*/ // you can reproduce the original variable
$newvar = json_decode($string); print_r($newvar);
/* prints
Array
(
[0] => hello
[1] => 42
[2] => Array
(
[0] => 1
[1] => two
) [3] => apple
)
*/
这看起来更为紧凑一些了。并且还兼容于Javascript和其他语言。可是对于一些很复杂的数据结构,可能会造成数据丢失
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()。能够让你在整个脚本停时前执行代码。
让我们看以下的一个演示样例:
// capture the start time
$start_time = microtime(true); // do some stuff
// ... // display how long the script took
echo "execution took: ".
(microtime(true) - $start_time).
" seconds.";
上面这个演示样例仅仅只是是用来计算某个函数执行的时间。然后。假设你在函数中间调用?exit()函数。那么你的最后的代码将不会被执行到。 而且,假设该脚本在浏览器终止(用户按停止button),其也无法被执行。 而当我们使用了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.";
}
版权声明:本文博主原创文章,博客,未经同意不得转载。