앞서 php7.0의 새로운 기능에 대한 자세한 설명을 소개해 드렸는데, 오늘은 php7.1과 php7.2의 새로운 기능에 대해 살펴보겠습니다.
php7.1 새로운 기능
1. Null 허용 유형
매개변수 및 반환 값에 대한 유형 선언은 유형 이름 앞에 물음표(?)를 추가하여 null로 표시할 수 있습니다. 함수 매개변수 또는 반환 값의 유형이 지정된 유형이거나 null임을 나타냅니다.
예를 보세요:
function testReturn(?string $name) { return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
인쇄 출력:
$ php php71.php string(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:14 Stack 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());
추가하면 문자열을 반환할까요 아니면 null을 반환할까요? 아무것도 반환할 수 없습니다. 오류가 보고됩니다.
2.void return type
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. 목록의 대괄호([]) 약어와 지정된 키
를 사용하면 목록을 빠르게 탐색하여 값을 얻을 수 있습니다. 배열에서. 이제 [] 약어를 사용할 수 있습니다.
$data = [ [1, 'Tom'], [2, 'Fred'], ]; // list() style list($id1, $name1) = $data[0]; // [] style [$id1, $name1] = $data[0]; // list() style foreach ($data as list($id, $name)) { // logic here with $id and $name } // [] style foreach ($data as [$id, $name]) { // logic here with $id and $name }
또한 이 업데이트된 목록은 인덱스 배열의 키를 지정할 수도 있습니다. 이 업그레이드는 훌륭하고 매우 편리합니다.
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ]; // list() style list("id" => $id1, "name" => $name1) = $data[0]; // [] style ["id" => $id1, "name" => $name1] = $data[0]; // list() style foreach ($data as list("id" => $id, "name" => $name)) { // logic here with $id and $name } // [] style foreach ($data as ["id" => $id, "name" => $name]) { // logic here with $id and $name }
이 함수를 사용할 수 없기 전에는 일반적으로 list:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ]; while (list($id, name) = each($data)) { echo "$key => $val\n"; }
를 사용하여 인덱스 배열을 탐색하기 위해 while + Each를 사용했습니다. 참고: Each 함수는 PHP 7.2에서 제거되었습니다! 따라서 인덱스 배열을 순회하는 데 이 방법을 사용하지 마세요
4. 클래스 상수 가시 범위 설정
이전에는 클래스의 상수가 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; }
사용 방법은 클래스의 방법과 동일합니다. 자세한 내용은 다루지 않겠습니다.
5. 음수 문자열 오프셋 지원
두 가지 업데이트가 있는데, 첫 번째는 문자열을 직접 가져오는 것이고, 두 번째는 strpos 함수의 세 번째 매개변수가 음수를 지원한다는 것입니다. 꼬리부터 취함을 나타냅니다.
var_dump("abcdef"[-2]); // e var_dump(strpos("aabbcc", "b", -3)); //3
문자열 변수는 변수 이름을 사용하지 않고 직접 값을 가져올 수 있습니다. php5.5에 추가되었습니다. 이제 꼬리에서 가져올 수 있습니다:
var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:e var_dump("abcdef"[2]); // 从前面取第2个,从0开始:c $string = 'bar'; echo $string[1], $string[-1]; // a r
6. 다중 조건 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는 대부분 성능 향상을 위한 하위 수준 업데이트입니다. 공통 구문 수준에는 업데이트가 많지 않으므로 여기서는 건너뛰겠습니다.
관련 추천: "PHP 튜토리얼"
위 내용은 PHP7.1 및 7.2의 새로운 기능에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!