php7.1 새로운 기능
유형 이름(null) 앞에 물음표(?
)를 추가하여 매개변수 및 반환 값의 유형 선언을 null로 표시할 수 있습니다. ). 함수 매개변수 또는 반환 값의 유형이 지정된 유형이거나 null임을 나타냅니다. ?
)来标记为空(null)。表明函数参数或者返回值的类型要么为指定类型,要么为 null。
看下例子:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
打印输出:
$ 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
如上如:第三个报了一个致命的错误。
再来看下,函数返回值是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; } }
[]
)简写以及增加指定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 函数移除了!所以,就不要用这种方式来遍历索引数组了
之前类里面额常量用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; }
使用方法和类的方法一样。就不多详述了。
有2个更新,1是字符串直接取,2是strpos函数第三个参数支持负数。表示从尾部取。
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大都是底层的更新,提高性能。没有太大常用语法层面的更新,这里就略过了。
之前写过php7.0以及老版本的php各大版本的跟新点以及新功能。今天看下php7.1和php7.2的新功能。
参数和返回值的类型声明可以通过在类型名称前添加一个问号(?
)来标记为空(null)。表明函数参数或者返回值的类型要么为指定类型,要么为 null。
看下例子:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
打印输出:
$ 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
如上如:第三个报了一个致命的错误。
再来看下,函数返回值是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; } }
[]
)简写以及增加指定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 函数移除了!所以,就不要用这种方式来遍历索引数组了
之前类里面额常量用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; }인쇄 출력:
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
Nullable
인 경우를 살펴보겠습니다. 🎜var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r🎜
?
를 추가하면 문자열 또는 null을 반환합니다. 아무것도 반환할 수 없습니다. 오류가 보고됩니다. 🎜🎜2.void return type🎜🎜PHP7.0에는 함수 반환 유형을 지정하는 기능이 추가되었지만 반환 유형을 void로 지정할 수는 없습니다. 7.1의 이 기능은 보완 사항입니다. void
반환 유형으로 정의된 함수는 null을 반환하더라도 반환 값을 가질 수 없습니다. 🎜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) { // ...}🎜또한 void는 반환 값에만 사용할 수 있고 매개 변수에는 사용할 수 없습니다. 예를 들어 다음 오류가 보고됩니다. 🎜rrreeerrreee🎜클래스 상속에서 메소드가 void 반환 유형으로 선언된 경우 하위 클래스가 이를 상속하고 재정의하면 void만 반환할 수 있으며, 그렇지 않으면 오류가 발생합니다. : 🎜rrreee🎜따라서 이렇게 해야 합니다. 오류가 보고되지 않습니다. 🎜rrreee🎜3. 대괄호(
[]
)는 목록의 약어이며 지정된 키🎜🎜를 추가하는 데 사용할 수 있습니다. 목록을 빠르게 탐색하여 배열의 값을 가져옵니다. 이제 []
약어를 사용할 수 있습니다. 🎜rrreee🎜또한 이 업데이트된 목록은 인덱스 배열의 키를 지정할 수도 있습니다. 이 업그레이드는 훌륭하고 매우 편리합니다. 🎜rrreee🎜이 기능을 사용할 수 없기 전에는 일반적으로 while
+ each
를 사용하여 list
를 사용하여 인덱스 배열을 탐색했습니다. 🎜rrreee🎜참고: PHP 7.2에서는 각 함수가 제거되었습니다! 따라서 인덱스 배열을 순회하는 데 이 방법을 사용하지 마세요🎜🎜3. 클래스 상수의 표시 범위 설정🎜🎜이전에는 클래스의 상수가 const
로 선언되었으며 표시되는 속성이 없었습니다. . 이제 메소드의 눈에 보이는 속성이 이식되었습니다. 🎜rrreee🎜사용 방법은 클래스의 방법과 동일합니다. 자세한 내용은 없습니다. 🎜🎜4. 음수 문자열 오프셋 지원🎜🎜 두 가지 업데이트가 있습니다. 첫 번째는 문자열을 직접 가져오는 것이고, 두 번째는 strpos 함수의 세 번째 매개변수가 음수를 지원한다는 것입니다. 꼬리부터 취함을 나타냅니다. 🎜rrreee🎜문자열 변수는 변수 이름을 사용하지 않고 직접 값을 가져올 수 있습니다. php5.5에 추가되었습니다. 이제 꼬리에서 가져올 수 있습니다: 🎜rrreee🎜5. 다중 조건 catch🎜🎜이전 try...catch 문에서 각 catch는 하나의 조건부 판단만 설정할 수 있습니다. 🎜rrreee🎜이제 여러 조건을 함께 처리할 수 있습니다. "|
"로 분할합니다. 🎜rrreee?
)를 추가하여 만들 수 있습니다. name >)을 사용하여 null로 표시합니다. 함수 매개변수 또는 반환 값의 유형이 지정된 유형이거나 null임을 나타냅니다. 🎜🎜예를 보세요: 🎜rrreee🎜인쇄 출력: 🎜rrreee🎜위와 동일: 세 번째는 치명적인 오류를 보고했습니다. 🎜🎜함수 반환 값이 Nullable
인 경우를 살펴보겠습니다. 🎜rrreee🎜 ?
를 추가하면 문자열 또는 null을 반환합니다. 아무것도 반환할 수 없습니다. 오류가 보고됩니다. 🎜🎜2.void return type🎜🎜PHP7.0에는 함수 반환 유형을 지정하는 기능이 추가되었지만 반환 유형을 void로 지정할 수는 없습니다. 7.1의 이 기능은 보완 사항입니다. void
반환 유형으로 정의된 함수는 null을 반환하더라도 반환 값을 가질 수 없습니다. 🎜rrreeerrreee🎜또한 void는 반환 값에만 사용할 수 있고 매개 변수에는 사용할 수 없습니다. 예를 들어 다음 오류가 보고됩니다. 🎜rrreeerrreee🎜클래스 상속에서 메소드가 void 반환 유형으로 선언된 경우 하위 클래스가 이를 상속하고 재정의하면 void만 반환할 수 있으며, 그렇지 않으면 오류가 발생합니다. : 🎜rrreee🎜따라서 이렇게 해야 합니다. 오류가 보고되지 않습니다. 🎜rrreee🎜3. 대괄호([]
)는 목록의 약어이며 지정된 키🎜🎜를 추가하는 데 사용할 수 있습니다. 목록을 빠르게 탐색하여 배열의 값을 가져옵니다. 이제 []
약어를 사용할 수 있습니다. 🎜rrreee🎜또한 이 업데이트된 목록은 인덱스 배열의 키를 지정할 수도 있습니다. 이 업그레이드는 훌륭하고 매우 편리합니다. 🎜rrreee🎜이 기능을 사용할 수 없기 전에는 일반적으로 while
+ each
를 사용하여 list
를 사용하여 인덱스 배열을 탐색했습니다. 🎜rrreee🎜참고: PHP 7.2에서는 각 함수가 제거되었습니다! 따라서 인덱스 배열을 순회하는 데 이 방법을 사용하지 마세요🎜🎜3. 클래스 상수의 표시 범위 설정🎜🎜이전에는 클래스의 상수가 const
로 선언되었으며 표시되는 속성이 없었습니다. . 이제 메소드의 눈에 보이는 속성이 이식되었습니다. 🎜rrreee🎜사용 방법은 클래스의 방법과 동일합니다. 자세한 내용은 다루지 않겠습니다. 🎜🎜4. 음수 문자열 오프셋 지원🎜🎜 두 가지 업데이트가 있습니다. 첫 번째는 문자열을 직접 가져오는 것이고, 두 번째는 strpos 함수의 세 번째 매개변수가 음수를 지원한다는 것입니다. 꼬리부터 취함을 나타냅니다. 🎜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大都是底层的更新,提高性能。没有太大常用语法层面的更新,这里就略过了。
相关推荐:
위 내용은 PHP7.1 및 7.2의 새로운 기능에 대한 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!