-
8个必备的PHP功能开辟
添加时间:2013-7-27 点击量:做过PHP开辟的法度员应当清楚,PHP中有很多内置的功能,把握了它们,可以帮助你在做PHP开辟时加倍驾轻就熟,本文将分享8个开辟必备的PHP功能,个个都很是实用,各位PHP开辟者可以或许把握。
1、传递随便率性数量的函数参数 我们在.NET或者JAVA编程中,一般函数参数个数都是固定的,然则PHP容许你应用随便率性个数的参数。下面这个示例向你显现了PHP函数的默认参数:1 // 两个默认参数的函数
2 function foo(¥arg1 = ”, ¥arg2 = ”) {
3 echo “arg1: ¥arg1\n”;
4 echo “arg2: ¥arg2\n”;
5 }
6 foo(‘hello’,world’);
7 / 输出:
8 arg1: hello
9 arg2: world
10 /
11 foo();
12 / 输出:
13 arg1:
14 arg2:
15 /
16 下面这个示例是PHP的不定参数用法,其应用到了 func_get_args()办法:
17 // 是的,形参列表为空
18 function foo() {
19 // 取得所有的传入参数的数组
20 ¥args = func_get_args();
21 foreach (¥args as ¥k => ¥v) {
22 echo “arg”.(¥k+1).”: ¥v\n”;
23 }
24 }
25 foo();
26 / 什么也不会输出 /
27 foo(‘hello’);
28 / 输出
29 arg1: hello
30 /
31 foo(‘hello’, ‘world’, ‘again’);
32 / 输出
33 arg1: hello
34 arg2: world
35 arg3: again
36 /
2、应用glob()查找文件 大项目组PHP函数的函数名从字面上都可以懂得其用处,然则当你看到 glob() 的时辰,你也许并不知道这是用来做什么的,其实glob()和scandir() 一样,可以用来查找文件,请看下面的用法:
1 // 取得所有的后缀为PHP的文件
2 ¥files = glob(‘.php’);
3 print_r(¥files);
4 / 输出:
5 Array
6 (
7 [0] => phptest.php
8 [1] => pi.php
9 [2] => post_output.php
10 [3] => test.php
11 )
12 /
你还可以查找多种后缀名:
1 // 取PHP文件和TXT文件
2 ¥files = glob(‘.{php,txt}’, GLOB_BRACE);
3 print_r(¥files);
4 / 输出:
5 Array
6 (
7 [0] => phptest.php
8 [1] => pi.php
9 [2] => post_output.php
10 [3] => test.php
11 [4] => log.txt
12 [5] => test.txt
13 )
14 /
你还可以加上路径:
1 ¥files = glob(‘../images/a.jpg’);
2 print_r(¥files);
3 / 输出:
4 Array
5 (
6 [0] => ../images/apple.jpg
7 [1] => ../images/art.jpg
8 )
9 /
若是你想获得绝对路径,你可以调用 realpath() 函数:
1 ¥files = glob(‘../images/a.jpg’);
2 // applies the function to each array element
3 ¥files = array_map(‘realpath’,¥files);
4 print_r(¥files);
5 / output looks like:
6 Array
7 (
8 [0] => C:\wamp\www\images\apple.jpg
9 [1] => C:\wamp\www\images\art.jpg
10 )
11 /
3、获取内存应用景象信息 PHP的内存收受接管机制已经很是强大,你也可以应用PHP脚本获取当前内存的应用景象,调用memory_get_usage() 函数获取当期内存应用景象,调用memory_get_peak_usage() 函数获取内存应用的峰值。参考代码如下:
1 echo “Initial: “.memory_get_usage().” bytes \n”;
2 / 输出
3 Initial: 361400 bytes
4 /
5 // 应用内存
6 for (¥i = 0; ¥i < 100000; ¥i++) {
7 ¥array []= md5(¥i);
8 }
9 // 删除一半的内存
10 for (¥i = 0; ¥i < 100000; ¥i++) {
11 unset(¥array[¥i]);
12 }
13 echo “Final: “.memory_get_usage().” bytes \n”;
14 / prints
15 Final: 885912 bytes
16 /
17 echo “Peak: “.memory_get_peak_usage().” bytes \n”;
18 / 输出峰值
19 Peak: 13687072 bytes
20 /
4、获取CPU应用景象信息 获取了内存应用景象,也可以应用PHP的 getrusage()获取CPU应用景象,该办法在windows下不成用。
1 print_r(getrusage());
2 / 输出
3 Array
4 (
5 [ru_oublock] => 0
6 [ru_inblock] => 0
7 [ru_msgsnd] => 2
8 [ru_msgrcv] => 3
9 [ru_maxrss] => 12692
10 [ru_ixrss] => 764
11 [ru_idrss] => 3864
12 [ru_minflt] => 94
13 [ru_majflt] => 0
14 [ru_nsignals] => 1
15 [ru_nvcsw] => 67
16 [ru_nivcsw] => 4
17 [ru_nswap] => 0
18 [ru_utime.tv_usec] => 0
19 [ru_utime.tv_sec] => 0
20 [ru_stime.tv_usec] => 6269
21 [ru_stime.tv_sec] => 0
22 )
23 /
这个布局看上出很晦涩,除非你对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万,并把它添加到秒的值后,可以获得有小数项目组的秒数。
1 // sleep for 3 seconds (non-busy)
2 sleep(3);
3 ¥data = getrusage();
4 echo “User time: “.
5 (¥data[ru_utime.tv_sec] +
6 ¥data[ru_utime.tv_usec] / 1000000);
7 echo “System time: “.
8 (¥data[ru_stime.tv_sec] +
9 ¥data[ru_stime.tv_usec] / 1000000);
10 / 输出
11 User time: 0.011552
12 System time: 0
13 /
是不占用体系时候的,我们可以来看下面的一个例子:
1 // loop 10 million times (busy)
2 for(¥i=0;¥i<10000000;¥i++) {
3 }
4 ¥data = getrusage();
5 echo “User time: “.
6 (¥data[ru_utime.tv_sec] +
7 ¥data[ru_utime.tv_usec] / 1000000);
8 echo “System time: “.
9 (¥data[ru_stime.tv_sec] +
10 ¥data[ru_stime.tv_usec] / 1000000);
11 / 输出
12 User time: 1.424592
13 System time: 0.004204
14 /
这花了大约14秒的CPU时候,几乎所有的都是用户的时候,因为没有体系调用。传统时候是CPU花费在体系调用上的上履行内核指令的时候。下面是一个例子:
1 ¥start = microtime(true);
2 // keep calling microtime for about 3 seconds
3 while(microtime(true) – ¥start < 3) {
4 }
5 ¥data = getrusage();
6 echo “User time: “.
7 (¥data[ru_utime.tv_sec] +
8 ¥data[ru_utime.tv_usec] / 1000000);
9 echo “System time: “.
10 (¥data[ru_stime.tv_sec] +
11 ¥data[ru_stime.tv_usec] / 1000000);
12 / prints
13 User time: 1.088171
14 System time: 1.675315
15 /
我们可以看到上方这个例子更耗CPU。
5、获取体系常量 PHP 供给很是有效的体系常量 可以让你获得当前的行号 (__LINE__),文件 (__FILE__),目次 (__DIR__),函数名 (__FUNCTION__),类名(__CLASS__),办法名(__METHOD__) 和名字空间 (__NAMESPACE__),很像C说话。
我们可以认为这些器材主如果用于调试,当也不必然,比如我们可以在include其它文件的时辰应用?__FILE__ (当然,你也可以在 PHP 5.3今后应用 __DIR__ ),下面是一个例子。1 // this is relative to the loaded script’s path
2 // it may cause problems when running scripts different directories
3 require_once(‘config/database.php’);
4 // this is always relative to this file’s path
5 // no matter where it was included
6 require_once(dirname(__FILE__) . ‘/config/database.php’);
下面是应用 __LINE__ 来输出一些debug的信息,如许有助于你调试法度:
1 // some code
2 // …
3 my_debug(“some debug message”, __LINE__);
4 / 输出
5 Line 4: some debug message
6 /
7 // some more code
8 // …
9 my_debug(“another debug message”, __LINE__);
10 / 输出
11 Line 11: another debug message
12 /
13 function my_debug(¥msg, ¥line) {
14 echo “Line ¥line: ¥msg\n”;
15 }
6、生成独一的id 很多伴侣都哄骗md5()来生成独一的编号,然则md5()有几个毛病:1、无序,导致数据库中排序机能降落。2、太长,须要更多的存储空间。其实PHP中自带一个函数来生成独一的id,这个函数就是uniqid()。下面是用法:
1 // generate unique string
2 echo uniqid();
3 / 输出
4 4bd67c947233e
5 /
6 // generate another unique string
7 echo uniqid();
8 / 输出
9 4bd67c9472340
10 /
该算法是按照CPU时候戳来生成的,所以在附近的时候段内,id前几位是一样的,这也便利id的排序,若是你想更好的避免反复,可以在id前加上前缀,如:
1 // 前缀
2 echo uniqid(‘foo_’);
3 / 输出
4 foo_4bd67d6cd8b8f
5 /
6 // 有更多的熵
7 echo uniqid(”,true);
8 / 输出
9 4bd67d6cd8b926.12135106
10 /
11 // 都有
12 echo uniqid(‘bar_’,true);
13 / 输出
14 bar_4bd67da367b650.43684647
15 /
7、序列化 PHP序列化功能大师可能用的斗劲多,也斗劲常见,当你须要把数据存到数据库或者文件中是,你可以哄骗PHP中的serialize() 和 unserialize()办法来实现序列化和反序列化,代码如下:
1 // 一个错杂的数组
2 ¥myvar = array(
3 ‘hello’,
4 42,
5 array(1,’two’),
6 ‘apple’
7 );
8 // 序列化
9 ¥string = serialize(¥myvar);
10 echo ¥string;
11 / 输出
12 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”;}
13 /
14 // 反序例化
15 ¥newvar = unserialize(¥string);
16 print_r(¥newvar);
17 / 输出
18 Array
19 (
20 [0] => hello
21 [1] => 42
22 [2] => Array
23 (
24 [0] => 1
25 [1] => two
26 )
27 [3] => apple
28 )
29 /
如何序列化成json格局呢,宁神,php也已经为你做好了,应用php 5.2以上版本的用户可以应用json_encode() 和 json_decode() 函数来实现json格局的序列化,代码如下:
1 // a complex array
2 ¥myvar = array(
3 ‘hello’,
4 42,
5 array(1,’two’),
6 ‘apple’
7 );
8 // convert to a string
9 ¥string = json_encode(¥myvar);
10 echo ¥string;
11 / prints
12 [hello,42,[1,two],”apple”]
13 /
14 // you can reproduce the original variable
15 ¥newvar = json_decode(¥string);
16 print_r(¥newvar);
17 / prints
18 Array
19 (
20 [0] => hello
21 [1] => 42
22 [2] => Array
23 (
24 [0] => 1
25 [1] => two
26 )
27 [3] => apple
28 )
29 /
8、字符串紧缩 说到紧缩,我们可能会想到文件紧缩,其实,字符串也是可以紧缩的。PHP供给了 gzcompress() 和gzuncompress() 函数:
1 ¥string =
2 “Lorem ipsum dolor sit amet, consectetur
3 adipiscing elit. Nunc ut elit id mi ultricies
4 adipiscing. Nulla facilisi. Praesent pulvinar,
5 sapien vel feugiat vestibulum, nulla dui pretium orci,
6 non ultricies elit lacus quis ante. Lorem ipsum dolor
7 sit amet, consectetur adipiscing elit. Aliquam
8 pretium ullamcorper urna quis iaculis. Etiam ac massa
9 sed turpis tempor luctus. Curabitur sed nibh eu elit
10 mollis congue. Praesent ipsum diam, consectetur vitae
11 ornare a, aliquam a nunc. In id magna pellentesque
12 tellus posuere adipiscing. Sed non mi metus, at lacinia
13 augue. Sed magna nisi, ornare in mollis in, mollis
14 sed nunc. Etiam at justo in leo congue mollis.
15 Nullam in neque eget metus hendrerit scelerisque
16 eu non enim. Ut malesuada lacus eu nulla bibendum
17 id euismod urna sodales. “;
18 ¥compressed = gzcompress(¥string);
19 echo “Original size: “. strlen(¥string).”\n”;
20 / 输出原始大小
21 Original size: 800
22 /
23 echo “Compressed size: “. strlen(¥compressed).”\n”;
24 / 输出紧缩后的大小
25 Compressed size: 418
26 /
27 // 解紧缩
28 ¥original = gzuncompress(¥compressed);
几乎有50% 紧缩比率。同时,你还可以应用 gzencode() 和 gzdecode() 函数来紧缩,只不消其用了不合的紧缩算法。
以上就是8个开辟必备的PHP功能,是不是都很实用呢?
原文出处:http://www.codeceo.com/8-php-functions.html
- 从汇编看c++函数的默认参数
- 解决规划:Python Version 2.7 required, which was not fo
- java虚拟机类加载
- BAE 景象下设备 struts2 + spring + hibernate(SSH)(二)stru
- Java7 一些新特点及脚本说话支撑API--笔记
- Inside The C++ Object Model 读书笔记(二)——静态成员变量与单例模式
- 恳求发送者与接管者解耦——号令模式(二)
- GitHub的应用(下)—— 如何一个已存在的 Repository
- 浅谈JSP网站开辟技巧中的两种模式
- 【说话处理惩罚与Python】4.7算法设计
相关文章