《PHP 7.1 新特性(2016发布)》要点:
本文介绍了PHP 7.1 新特性(2016发布),希望对您有用。如果有疑问,可以联系我们。
相关主题:PHP开发
去年2016年PHP7.1就发布了,但是一直没更新,特地补上这一节,看看它的新特性。
可空类型主要用于参数类型声明很函数返回值声明。
主要的两种形式如下:
<?php function answer(): ?int { return null; //ok } function answer(): ?int { return 42; // ok } function say(?string $msg) { if ($msg) { echo $msg; } }
从例子很容易理解,所指的就是通过 ?
的形式表明函数参数或者返回值的类型要么为指定类型,要么为 null
。
此方法也可用于接口函数的定义:
<?php interface Fooable { function foo(?Fooable $f); }
但有一个需要注意的地方:如果函数本身定义了参数类型并且没有默认值,即使是可空的,也不能省略,否则会触发错误。如下:
<?php function foo_nullable(?Bar $bar) {} foo_nullable(new Bar); // 可行 foo_nullable(null); // 可行 foo_nullable(); // 不可行
但是如果以上函数的参数定义为 ?Bar $bar = null
的形式,则第三种写法也是可行的。因为 = null
实际上相当于 ?
的超集,对于可空类型的参数,可以设定 null
为默认值。
我们知道在 PHP5.4 之前只能通过 array()
来定义数组,5.4之后添加了 []
的简化写法(省略了5个字符还是很实在的)。
<?php // 5.4 之前 $array = array(1, 2, 3); $array = array("a" => 1, "b" => 2, "c" => 3); // 5.4 及之后 $array = [1, 2, 3]; $array = ["a" => 1, "b" => 2, "c" => 3];
引申到另外一个问题上,如果我们要把数组的值赋值给不同的变量,可以通过 list
来实现:
<?php list($a, $b, $c) = $array;
是否也可以通过 []
的简写来实现呢?
<?php [$a, $b, $c] = $array;
以及下一个特性中会提到的 list 指定 key:
<?php ["a" => $a, "b" => $b, "c" => $c] = $array;
PHP7.1 实现了这个特性。但是要注意的是:出现在左值中的 []
并不是数组的简写,是 list()
的简写。
但是并不仅仅如此,新的 list()
的实现并不仅仅可以出现在左值中,也能在 foreach
循环中使用:
<?php foreach ($points as ["x" => $x, "y" => $y]) { var_dump($x, $y); }
不过因为实现的问题,list()
和 []
不能相互嵌套使用:
PHP7.0 添加了指定函数返回类型的特性,但是返回类型却不能指定为 void
,7.1 的这个特性算是一个补充:
<?php function should_return_nothing(): void { return 1; // Fatal error: A void function must not return a value }
以下两种情况都可以通过验证:
<?php function lacks_return(): void { // valid } function returns_nothing(): void { return; // valid }
定义返回类型为 void
的函数不能有返回值,即使返回 null
也不行:
<?php function returns_one(): void { return 1; // Fatal error: A void function must not return a value}function returns_null(): void { return null; // Fatal error: A void function must not return a value }
此外 void
也只适用于返回类型,并不能用于参数类型声明,或者会触发错误:
<?php function foobar(void $foo) { // Fatal error: void cannot be used as a parameter type }
类函数中对于返回类型的声明也不能被子类覆盖,否则会触发错误:
<?php class Foo{ public function bar(): void { } } class Foobar extends Foo{ public function bar(): array { // Fatal error: Declaration of Foobar::bar() must be compatible with Foo::bar(): void } }
这个特性说起来比较简单,就是现在类中的常量支持使用 public
、private
和 protected
修饰了:
<?php class Token { // 常量默认为 public const PUBLIC_CONST = 0; // 可以自定义常量的可见范围 private const PRIVATE_CONST = 0; protected const PROTECTED_CONST = 0; public const PUBLIC_CONST_TWO = 0; // 多个常量同时声明只能有一个属性 private const FOO = 1, BAR = 2; }
此外,接口(interface)中的常量只能是 public
属性:
<?php interface ICache { public const PUBLIC = 0; const IMPLICIT_PUBLIC = 1; }
为了应对变化,反射类的实现也相应的丰富了一下,增加了 getReflectionConstant
和getReflectionConstants
两个方法用于获取常量的额外属性:
<?php class testClass { const TEST_CONST = 'test'; } $obj = new ReflectionClass( "testClass" ); $const = $obj->getReflectionConstant( "TEST_CONST" ); $consts = $obj->getReflectionConstants();
在以往的 try ... catch
语句中,每个 catch
只能设定一个条件判断:
<?php try { // Some code... } catch (ExceptionType1 $e) { // 处理 ExceptionType1 } catch (ExceptionType2 $e) { // 处理 ExceptionType2 } catch (\Exception $e) { // ... }
新的实现中可以在一个 catch
中设置多个条件,相当于或的形式判断:
<?php try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (\Exception $e) { // ... }
对于异常的处理简化了一些。
转载请注明本页网址:
http://www.vephp.com/jiaocheng/22.html