8个必备的PHP功能实例代码
做过PHP开发的程序员应该清楚,PHP中有很多内置的功能,掌握了它们,可以帮助你在做PHP开发时更加得⼼应⼿,本⽂将分享8个开发必备的PHP功能,个个都⾮常实⽤,希望各位PHP开发者能够掌握。
1、传递任意数量的函数参数
2、使⽤glob()查⽂件
3、获取内存使⽤情况信息
4、获取CPU使⽤情况信息
5、获取系统常量
6、⽣成唯⼀的id
7、序列化
8、字符串压缩
1、传递任意数量的函数参数我们在.NET或者JAVA编程中,⼀般函数参数个数都是固定的,但是PHP允许你使⽤任意个数的参数。下⾯这个⽰例向你展⽰了PHP函数的默认参数:
复制代码代码如下:
// 两个默认参数的函数
function foo($arg1 = ", $arg2 = ") {
echo "arg1: $arg1\n";
echo "arg2: $arg2\n";
}
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\n";
}
}
foo();
/* 什么也不会输出 */
foo('hello');
/* 输出
arg1: hello
*/
foo('hello', 'world', 'again');
/
* 输出
arg1: hello
arg2: world
arg3: again
*/
2、使⽤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
phpjson格式化输出)
*/
还可以查多种后缀名:
复制代码代码如下:
/
/ 取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] =>
[5] =>
)
*/
还可以加上路径:
复制代码代码如下:
$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的内存回收机制已经⾮常强⼤,你也可以使⽤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使⽤情况信息获取了内存使⽤情况,也可以使⽤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_nsi
gnals: 收到的信号 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
*/
是不占⽤系统时间的,我们可以来看下⾯的⼀个例⼦:
复制代码代码如下:
// 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()来⽣成唯⼀的编号,但是md5()有⼏个缺点:1、⽆序,导致数据库中排序性能下降。
2、太长,需要更多的存储空间。其实PHP中⾃带⼀个函数来⽣成唯⼀的id,这个函数就是uniqid()。下⾯是⽤法:
复制代码代码如下:
// generate unique string
echo uniqid();
/* 输出
4bd67c947233e
*/
// generate another unique string
echo uniqid();
/* 输出
4bd67c9472340
*/
该算法是根据CPU时间戳来⽣成的,所以在相近的时间段内,id前⼏位是⼀样的,这也⽅便id的排序,如果你想更好的避免重复,可以在id前加上前缀,如:
复制代码代码如下:
// 前缀
echo uniqid('foo_');
/* 输出
foo_4bd67d6cd8b8f
*/
// 有更多的熵
echo uniqid(",true);
/* 输出
4bd67d6cd8b926.12135106
*/
// 都有
echo uniqid('bar_',true);
/* 输出
bar_4bd67da367b650.43684647
*/
7、序列化 PHP序列化功能⼤家可能⽤的⽐较多,也⽐较常见,当你需要把数据存到数据库或者⽂件中是,你可以利⽤PHP 中的serialize() 和 unserialize()⽅法来实现序列化和反序列化,代码如下:
复制代码代码如下:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论