这么多好的特性,好的方法,为什么不使用呢,也希望php越来越好。
在这里整理 php 5.1 ,php5.2,php5.3,php5.4,php5.5,php5.6 ,php7,php7.1 所有新特性,已备大家学习及使用
buid-in web server内置了一个简单的web服务器
把当前目录作为root document只需要这条命令即可:
php -s localhost:3300
也可以指定其它路径
php -s localhost:3300 -t /path/to/root
还可以指定路由
php -s localhost:3300 router.php
命名空间(php5.3)
命名空间的分隔符为反斜杆\
namespace fox\lanmps\table; class select {}
获取完整类别名称
php5.3 中引入命名空间的别名类和命名空间短版本的功能。虽然这并不适用于字符串类名称
use some\deeply\nested\namespace\foobar; // does not work, because this will try to use the global `foobar` class $reflection = new reflectionclass('foobar'); echo foobar::class;
为了解决这个问题采用新的foobar::class语法,它返回类的完整类别名称
命名空间 use 操作符开始支持函数和常量的导入
namespace name\space { const foo = 42; function f() { echo __function__."\n"; } } namespace { use const name\space\foo; use function name\space\f; echo foo."\n"; f(); }
输出
42
name\space\f
group use declarations
从同一 namespace 导入的类、函数和常量现在可以通过单个 use 语句 一次性导入了。
//php7之前use some\namespace\classa;use some\namespace\classb;use some\namespace\classc as c;use function some\namespace\fn_a;use function some\namespace\fn_b;use function some\namespace\fn_c;use const some\namespace\consta;use const some\namespace\constb;use const some\namespace\constc;// php7之后use some\namespace\{classa, classb, classc as c};use function some\namespace\{fn_a, fn_b, fn_c};use const some\namespace\{consta, constb, constc};
支持延迟静态绑定
static关键字来引用当前类,即实现了延迟静态绑定
class a { public static function who() { echo __class__; } public static function test() { static::who(); // 这里实现了延迟的静态绑定 } } class b extends a { public static function who() { echo __class__; } }b::test();
输出结果:
b
支持goto语句
多数计算机程序设计语言中都支持无条件转向语句goto,当程序执行到goto语句时,即转向由goto语句中的标号指出的程序位置继续执行。尽管goto语句有可能会导致程序流程不清晰,可读性减弱,但在某些情况下具有其独特的方便之处,例如中断深度嵌套的循环和 if 语句。
goto a; echo 'foo'; a: echo 'bar'; for($i=0,$j=50; $i<100; $i++) { while($j--) { if($j==17) goto end; } } echo "i = $i"; end: echo 'j hit 17';
支持闭包、lambda/anonymous函数
闭包(closure)函数和lambda函数的概念来自于函数编程领域。例如javascript 是支持闭包和 lambda 函数的最常见语言之一。
在php中,我们也可以通过create_function()在代码运行时创建函数。但有一个问题:创建的函数仅在运行时才被编译,而不与其它代码同时被编译成执行码,因此我们无法使用类似apc这样的执行码缓存来提高代码执行效率。
在php5.3中,我们可以使用lambda/匿名函数来定义一些临时使用(即用即弃型)的函数,以作为array_map()/array_walk()等函数的回调函数。
echo preg_replace_callback('~-([a-z])~', function ($match) { return strtoupper($match[1]); }, 'hello-world'); // 输出 helloworld $greet = function($name) { printf("hello %s\r\n", $name); }; $greet('world'); $greet('php'); //...在某个类中 $callback = function ($quantity, $product) use ($tax, &$total) { $priceperitem = constant(__class__ . "::price_" . strtoupper($product)); $total += ($priceperitem * $quantity) * ($tax + 1.0); };
魔术方法__callstatic()和__invoke()
php中原本有一个魔术方法__call(),当代码调用对象的某个不存在的方法时该魔术方法会被自动调用。新增的__callstatic()方法则只用于静态类方法。当尝试调用类中不存在的静态方法时,__callstatic()魔术方法将被自动调用。
class methodtest { public function __call($name, $arguments) { // 参数 $name 大小写敏感 echo "调用对象方法 '$name' " . implode(' -- ', $arguments). "\n"; } /** php 5.3.0 以上版本中本类方法有效 */ public static function __callstatic($name, $arguments) { // 参数 $name 大小写敏感 echo "调用静态方法 '$name' " . implode(' -- ', $arguments). "\n"; } } $obj = new methodtest; $obj->runtest('通过对象调用'); methodtest::runtest('静态调用'); // as of php 5.3.0
以上代码执行后输出如下:
调用对象方法’runtest’ –- 通过对象调用调用静态方法’runtest’ –- 静态调用
以函数形式来调用对象时,__invoke()方法将被自动调用。
class methodtest { public function __call($name, $arguments) { // 参数 $name 大小写敏感 echo "calling object method '$name' " . implode(', ', $arguments). "\n"; } /** php 5.3.0 以上版本中本类方法有效 */ public static function __callstatic($name, $arguments) { // 参数 $name 大小写敏感 echo "calling static method '$name' " . implode(', ', $arguments). "\n"; } } $obj = new methodtest; $obj->runtest('in object context'); methodtest::runtest('in static context'); // as of php 5.3.0
nowdoc语法
用法和heredoc类似,但使用单引号。heredoc则需要通过使用双引号来声明。
nowdoc中不会做任何变量解析,非常适合于传递一段php代码。
// nowdoc 单引号 php 5.3之后支持 $name = 'myname'; echo <<<'eot' my name is "$name". eot; //上面代码输出 my name is "$name". ((其中变量不被解析) // heredoc不加引号 echo <<<foobar hello world! foobar; //或者 双引号 php 5.3之后支持 echo <<<"foobar" hello world! foobar;
支持通过heredoc来初始化静态变量、类成员和类常量。
// 静态变量 function foo() { static $bar = <<<label nothing in here... label; } // 类成员、常量 class foo { const bar = <<<foobar constant example foobar; public $baz = <<<foobar property example foobar; }
在类外也可使用const来定义常量
//php中定义常量通常是用这种方式 define("constant", "hello world."); //并且新增了一种常量定义方式 const constant = 'hello world';
三元运算符增加了一个快捷书写方式
原本格式为是(expr1) ? (expr2) : (expr3)
如果expr1结果为true,则返回expr2的结果。
新增一种书写方式,可以省略中间部分,书写为expr1 ?: expr3
如果expr1结果为true,则返回expr1的结果
$expr1=1;$expr2=2;//原格式 $expr=$expr1?$expr1:$expr2 //新格式 $expr=$expr1?:$expr2
输出结果:
1
1
空合并运算符()
简化判断
$param = $_get['param'] 1;
相当于:
$param = isset($_get['param']) ? $_get['param'] : 1;
json更懂中文(json_unescaped_unicode)
echo json_encode("中文", json_unescaped_unicode); //输出:"中文"
二进制
$bin = 0b1101; echo $bin; //13
unicode codepoint 转译语法
这接受一个以16进制形式的 unicode codepoint,并打印出一个双引号或heredoc包围的 utf-8 编码格式的字符串。 可以接受任何有效的 codepoint,并且开头的 0 是可以省略的。
echo "\u{9876}"
旧版输出:\u{9876}
新版输入:顶
使用 ** 进行幂运算
加入右连接运算符 * 来进行幂运算。 同时还支持简写的 *= 运算符,表示进行幂运算并赋值。
printf("2 ** 3 == %d\n", 2 ** 3);printf("2 ** 3 ** 2 == %d\n", 2 ** 3 ** 2);$a = 2;$a **= 3;printf("a == %d\n", $a);
输出
2 ** 3 == 8
2 * 3 * 2 == 512
a == 8
太空船操作符(组合比较符)
太空船操作符用于比较两个表达式。当 a大于、等于或小于
以上就是整合php5.x到php7.1.x的特性的详细内容。