php7.1 新增功能
1.可為空(Nullable)類型參數和返回值的類型聲明可以通過在類型名稱前添加一個問號(?
)來標記為空(null)。表明函數參數或者返回值的類型要么為指定類型,要么為 null。
看下例子:
function testReturn(?string $name){ return $name;}var_dump(testReturn('yangyi'));var_dump(testReturn(null));var_dump(testReturn2());
打印輸出:
$ php php71.phpstring(6) "yangyi"NULLPHP 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
如上如:第三個報了一個致命的錯誤。
再來看下,函數返回值是Nullable
的情況:
function testReturn3() : ?string{ //return "abc"; //return null;}var_dump(testReturn3());
如果加了?
要么返回 string ,要么返回null。不能啥也不返還。會報錯。
PHP7.0 添加了指定函數返回類型的特性,但是返回類型卻不能指定為 void,7.1 的這個特性算是一個補充。定義返回類型為 void
的函數不能有返回值,即使返回 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 html' target='_blank'>value in /php71.php on line 70
還有就是,void 只能用于返回值,不能用于參數中。比如下面的會報錯:
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
如果在類的繼承中,申明為void返回類型的方法,子類要是繼承重寫,也只能返回void, 否則會觸發錯誤:
<?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 }}
所以,你必須這樣,就不會報錯:
class Foo{ public $a; public function bar(): void { $this->a = 2; }}class Foobar extends Foo{ // 覆蓋成功 public function bar(): void { $this->a = 3; }}3.list 的方括號(
[]
)簡寫以及增加指定key可以用list 來快速遍歷得到數組里面的值。現在可以用[]
簡寫了。
$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}
此外,此次更新的list,針對索引數組,還可以指定 key,這個升級非常棒,非常方便。
$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}
在這個功能沒有之前,我們一般會用while
+ each
的方式來用list
遍歷索引數組:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'],];while (list($id, name) = each($data)) { echo "$key => $val/n";}
注意:PHP 7.2 中已經將 each 函數移除了!所以,就不要用這種方式來遍歷索引數組了
3.類常量可見范圍設定之前類里面額常量用const
申明,是沒有可見屬性的。現在把方法的可見屬性移植了過來:
<?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;}
使用方法和類的方法一樣。就不多詳述了。
4.支持負的字符串偏移有2個更新,1是字符串直接取,2是strpos函數第三個參數支持負數。表示從尾部取。
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
string變量可以直接取值,不用通過變量名,是在php5.5加入的。現在可以從尾部?。?/p>
var_dump("abcdef"[-2]); // 從末尾取倒數第2個字符:evar_dump("abcdef"[2]); // 從前面取第2個,從0開始:c$string = 'bar';echo $string[1], $string[-1]; // a r5.多條件 catch
在以往的 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) { // ...}php7.2
php 7.2大都是底層的更新,提高性能。沒有太大常用語法層面的更新,這里就略過了。
之前寫過php7.0以及老版本的php各大版本的跟新點以及新功能。今天看下php7.1和php7.2的新功能。
php7.1 新增功能1.可為空(Nullable)類型參數和返回值的類型聲明可以通過在類型名稱前添加一個問號(?
)來標記為空(null)。表明函數參數或者返回值的類型要么為指定類型,要么為 null。
看下例子:
function testReturn(?string $name){ return $name;}var_dump(testReturn('yangyi'));var_dump(testReturn(null));var_dump(testReturn2());
打印輸出:
$ php php71.phpstring(6) "yangyi"NULLPHP 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
如上如:第三個報了一個致命的錯誤。
再來看下,函數返回值是Nullable
的情況:
function testReturn3() : ?string{ //return "abc"; //return null;}var_dump(testReturn3());
如果加了?
要么返回 string ,要么返回null。不能啥也不返還。會報錯。
PHP7.0 添加了指定函數返回類型的特性,但是返回類型卻不能指定為 void,7.1 的這個特性算是一個補充。定義返回類型為 void
的函數不能有返回值,即使返回 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
還有就是,void 只能用于返回值,不能用于參數中。比如下面的會報錯:
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
如果在類的繼承中,申明為void返回類型的方法,子類要是繼承重寫,也只能返回void, 否則會觸發錯誤:
<?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 }}
所以,你必須這樣,就不會報錯:
class Foo{ public $a; public function bar(): void { $this->a = 2; }}class Foobar extends Foo{ // 覆蓋成功 public function bar(): void { $this->a = 3; }}3.list 的方括號(
[]
)簡寫以及增加指定key可以用list 來快速遍歷得到數組里面的值。現在可以用[]
簡寫了。
$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}
此外,此次更新的list,針對索引數組,還可以指定 key,這個升級非常棒,非常方便。
$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}
在這個功能沒有之前,我們一般會用while
+ each
的方式來用list
遍歷索引數組:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'],];while (list($id, name) = each($data)) { echo "$key => $val/n";}
注意:PHP 7.2 中已經將 each 函數移除了!所以,就不要用這種方式來遍歷索引數組了
3.類常量可見范圍設定之前類里面額常量用const
申明,是沒有可見屬性的?,F在把方法的可見屬性移植了過來:
<?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;}
使用方法和類的方法一樣。就不多詳述了。
4.支持負的字符串偏移有2個更新,1是字符串直接取,2是strpos函數第三個參數支持負數。表示從尾部取。
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
string變量可以直接取值,不用通過變量名,是在php5.5加入的?,F在可以從尾部?。?/p>
var_dump("abcdef"[-2]); // 從末尾取倒數第2個字符:evar_dump("abcdef"[2]); // 從前面取第2個,從0開始:c$string = 'bar';echo $string[1], $string[-1]; // a r5.多條件 catch
在以往的 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) { // ...}php7.2
php 7.2大都是底層的更新,提高性能。沒有太大常用語法層面的更新,這里就略過了。
相關推薦:
談談 PHP7新增功能
PHP7新增 功能,php7新增功能
PHP5.2至5.6的新增功能詳解
以上就是實例詳解PHP7.1和7.2新增功能的詳細內容,更多請關注 其它相關文章!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答