Home >Backend Development >PHP Tutorial >Detailed examples of new features in PHP7.1 and 7.2
php7.1 New features
The type declaration of parameters and return values can be made by adding a question mark () before the type name ?
) to mark it as null. Indicates that the type of the function parameter or return value is either the specified type or null.
Look at the example:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
Print output:
$ php php71.phpstring(6) "yangyi"NULL PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to function testReturn(), 0 passed in php71.php on line 22 and exactly 1 expected in php71.php:14Stack trace:#0 php71.php(22): testReturn()#1 {main} thrown in php71.php on line 14
Same as above: The third one reported a fatal error.
Let’s look at the situation where the function return value is Nullable
:
function testReturn3() : ?string{ //return "abc"; //return null;} var_dump(testReturn3());
If ?
is added, either string or null will be returned. You cannot return nothing. An error will be reported.
PHP7.0 added the feature of specifying the function return type, but the return type cannot be specified as void. This feature of 7.1 is a supplement. A function defined with a return type of void
cannot have a return value, even if it returns null:
function testReturn4() : void{ //1. 要么啥都不返还 ok //2. 要么只return; ok //return; //3. return null 也会报错 //return null; //4. return 4 会报错 //return 4;}
Fatal error: A void function must not return a value in /php71.php on line 70
Also, void can only be used for return values and not for parameters. For example, the following error will be reported:
function testReturn6(void $a) : void{} var_dump(testReturn6());
PHP Fatal error: void cannot be used as a parameter type in php71.php on line 73
If a method is declared as void return type in class inheritance, if the subclass inherits and overrides it, it can only return void, otherwise an error will be triggered:
<?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 } }
So, you must do this, so you won’t report an error:
class Foo{ public $a; public function bar(): void { $this->a = 2; } }class Foobar extends Foo{ // 覆盖成功 public function bar(): void { $this->a = 3; } }
[]
) abbreviation and adding the specified key can be used list to quickly traverse to get the values in the array. Now you can use []
abbreviation.
$data = [ [1, 'Tom'], [2, 'Fred'], ];// list() stylelist($id1, $name1) = $data[0];// [] style[$id1, $name1] = $data[0];// list() styleforeach ($data as list($id, $name)) { // logic here with $id and $name}// [] styleforeach ($data as [$id, $name]) { // logic here with $id and $name}
In addition, this updated list can also specify a key for the index array. This upgrade is great and very convenient.
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];// list() stylelist("id" => $id1, "name" => $name1) = $data[0]; // [] style["id" => $id1, "name" => $name1] = $data[0]; // list() styleforeach ($data as list("id" => $id, "name" => $name)) { // logic here with $id and $name } // [] styleforeach ($data as ["id" => $id, "name" => $name]) { // logic here with $id and $name}
Before this function was not available, we usually used while
+ each
to traverse the index array using list
:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];while (list($id, name) = each($data)) { echo "$key => $val\n"; }
Note: The each function has been removed in PHP 7.2! Therefore, do not use this method to traverse the index array
Before, the constants in the class were declared with const
, has no visible attributes. Now the visible attributes of the method are transplanted:
<?php class ConstDemo { // 常量默认为 public const PUBLIC_CONST = 0; // 可以自定义常量的可见范围 public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; // 多个常量同时声明只能有一个属性 private const FOO = 1, BAR = 2; }
The usage method is the same as the method of the class. I won’t go into details.
There are 2 updates, 1 is to take the string directly, 2 is that the third parameter of strpos function supports negative numbers. Indicates taking from the tail.
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
The string variable can take the value directly without passing the variable name. It was added in php5.5. Now you can take it from the tail:
var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r
In the previous try...catch statement, each catch can only set one conditional judgment:
try { // Some code...} catch (ExceptionType1 $e) { // 处理 ExceptionType1} catch (ExceptionType2 $e) { // 处理 ExceptionType2} catch (Exception $e) { // ...}
Now multiple ones can be processed together. Separate with "|
".
try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (Exception $e) { // ...}
php 7.2 is mostly a bottom-level update to improve performance. There are not many updates at the common syntax level, so we will skip them here.
I have previously written about the new features and new features of php7.0 and older versions of php. Today let’s take a look at the new features of php7.1 and php7.2.
The type declaration of parameters and return values can be made by adding a question mark before the type name ( ?
) to mark it as null. Indicates that the type of a function parameter or return value is either the specified type or null.
Look at the example:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
Print output:
$ php php71.phpstring(6) "yangyi"NULL PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to function testReturn(), 0 passed in php71.php on line 22 and exactly 1 expected in php71.php:14Stack trace:#0 php71.php(22): testReturn()#1 {main} thrown in php71.php on line 14
Same as above: The third one reported a fatal error.
Let’s look at the situation where the function return value is Nullable
:
function testReturn3() : ?string{ //return "abc"; //return null;} var_dump(testReturn3());
If ?
is added, either string or null will be returned. You cannot return nothing. An error will be reported.
PHP7.0 added the feature of specifying the function return type, but the return type cannot be specified as void. This feature of 7.1 is a supplement. A function defined with a return type of void
cannot have a return value, even if it returns null:
function testReturn4() : void{ //1. 要么啥都不返还 ok //2. 要么只return; ok //return; //3. return null 也会报错 //return null; //4. return 4 会报错 //return 4;}
Fatal error: A void function must not return a value in /php71.php on line 70
Also, void can only be used for return values and not for parameters. For example, the following error will be reported:
function testReturn6(void $a) : void{} var_dump(testReturn6());
PHP Fatal error: void cannot be used as a parameter type in php71.php on line 73
If a method is declared as void return type in class inheritance, if the subclass inherits and overrides it, it can only return void, otherwise an error will be triggered:
<?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 } }
So, you must do this, so you won’t report an error:
class Foo{ public $a; public function bar(): void { $this->a = 2; } }class Foobar extends Foo{ // 覆盖成功 public function bar(): void { $this->a = 3; } }
[]
) abbreviation and adding the specified key can be used list to quickly traverse to get the values in the array. Now you can use []
abbreviation.
$data = [ [1, 'Tom'], [2, 'Fred'], ];// list() stylelist($id1, $name1) = $data[0];// [] style[$id1, $name1] = $data[0]; // list() styleforeach ($data as list($id, $name)) { // logic here with $id and $name} // [] styleforeach ($data as [$id, $name]) { // logic here with $id and $name}
In addition, this updated list can also specify a key for the index array. This upgrade is great and very convenient.
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];// list() stylelist("id" => $id1, "name" => $name1) = $data[0]; // [] style["id" => $id1, "name" => $name1] = $data[0]; // list() styleforeach ($data as list("id" => $id, "name" => $name)) { // logic here with $id and $name}// [] styleforeach ($data as ["id" => $id, "name" => $name]) { // logic here with $id and $name}
Before this function was not available, we usually used while
+ each
to traverse the index array using list
:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];while (list($id, name) = each($data)) { echo "$key => $val\n"; }
Note: The each function has been removed in PHP 7.2! Therefore, do not use this method to traverse the index array
Previously, the constants in the class were declared with const
, has no visible attributes. Now the visible attributes of the method are transplanted:
<?php class ConstDemo { // 常量默认为 public const PUBLIC_CONST = 0; // 可以自定义常量的可见范围 public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; // 多个常量同时声明只能有一个属性 private const FOO = 1, BAR = 2; }
The usage method is the same as the method of the class. I won’t go into details.
There are 2 updates, 1 is to take the string directly, 2 is that the third parameter of strpos function supports negative numbers. Indicates taking from the tail.
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
string变量可以直接取值,不用通过变量名,是在php5.5加入的。现在可以从尾部取:
var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r
在以往的 try … catch 语句中,每个 catch 只能设定一个条件判断:
try { // Some code...} catch (ExceptionType1 $e) { // 处理 ExceptionType1} catch (ExceptionType2 $e) { // 处理 ExceptionType2} catch (Exception $e) { // ...}
现在可以多个一起处理。用”|
” 分割。
try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (Exception $e) { // ...}
php 7.2大都是底层的更新,提高性能。没有太大常用语法层面的更新,这里就略过了。
相关推荐:
The above is the detailed content of Detailed examples of new features in PHP7.1 and 7.2. For more information, please follow other related articles on the PHP Chinese website!