PHP5.5 ~ PHP7.2 새로운 기능 배열
1. PHP 5.5.x에서 PHP 5.6.x로 포팅
이전 PHP 버전에서는 상수를 정의하고, 속성을 선언하고, 함수 매개변수에 대한 기본값을 지정하려면 정적 값을 사용해야 합니다. 이제 숫자, 문자열 리터럴 및 기타 상수를 포함한 숫자 표현식을 사용하여 상수를 정의하고, 속성을 선언하고, 함수 매개변수의 기본값을 설정할 수 있습니다.
<?php const ONE = 1; const TWO = ONE * 2; class C { const THREE = TWO + 1; const ONE_THIRD = ONE / self::THREE; const SENTENCE = 'The value of THREE is '.self::THREE; }
이제 const 키워드를 통해 배열 유형의 상수를 정의할 수 있습니다.
<?php const ARR = ['a', 'b']; echo ARR[0];
...
연산자를 사용하여 가변 길이 매개변수 함수 정의...
运算符定义变长参数函数现在可以不依赖 func_get_args(), 使用 ... 运算符 来实现 变长参数函数。
<?php function f($req, $opt = null, ...$params) { // $params 是一个包含了剩余参数的数组 printf('$req: %d; $opt: %d; number of params: %d'."\n", $req, $opt, count($params)); } f(1); f(1, 2); f(1, 2, 3); f(1, 2, 3, 4); ?>
以上例程会输出:
$req: 1; $opt: 0; number of params: 0 $req: 1; $opt: 2; number of params: 0 $req: 1; $opt: 2; number of params: 1 $req: 1; $opt: 2; number of params: 2
...
运算符进行参数展开在调用函数的时候,使用 ... 运算符, 将 数组 和 可遍历 对象展开为函数参数。 在其他编程语言,比如 Ruby中,这被称为连接运算符。
<?php function add($a, $b, $c) { return $a + $b + $c; } $operators = [2, 3]; echo add(1, ...$operators); ?>
以上例程会输出:
6
use 运算符 被进行了扩展以支持在类中导入外部的函数和常量。 对应的结构为 use function 和 use const。
<?php namespace Name\Space { const FOO = 42; function f() { echo __FUNCTION__."\n"; } } namespace { use const Name\Space\FOO; use function Name\Space\f; echo FOO."\n"; f(); } ?>
以上例程会输出:
42 Name\Space\f
推荐(免费):PHP7
二、从PHP 5.6.x 移植到 PHP 7.0.x
标量类型声明 有两种模式: 强制 (默认) 和 严格模式。 现在可以使用下列类型参数(无论用强制模式还是严格模式): 字符串(string), 整数 (int), 浮点数 (float), 以及布尔值 (bool)。
<?php // Coercive mode function sumOfInts(int ...$ints) { return array_sum($ints); } var_dump(sumOfInts(2, '3', 4.1));
以上例程会输出:
int(9)
PHP 7 增加了对返回类型声明的支持。 类似于参数类型声明,返回类型声明指明了函数返回值的类型。可用的类型与参数声明中可用的类型相同。
<?php function arraysSum(array ...$arrays): array { return array_map(function(array $array): int { return array_sum($array); }, $arrays); }
由于日常使用中存在大量同时使用三元表达式和 isset()的情况, 我们添加了null合并运算符 (??
) 这个语法糖。如果变量存在且值不为NULL, 它就会返回自身的值,否则返回它的第二个操作数。
<?php // Fetches the value of $_GET['user'] and returns 'nobody' if it does not exist. $username = $_GET['user'] ?? 'nobody'; // This is equivalent to: $username = isset($_GET['user']) ? $_GET['user'] : 'nobody'; // Coalesces can be chained: this will return the first defined value out of $_GET['user'], $_POST['user'], and 'nobody'. $username = $_GET['user'] ?? $_POST['user'] ?? 'nobody'; ?>
太空船操作符用于比较两个表达式。当$a小于、等于或大于$b时它分别返回-1、0或1。 比较的原则是沿用 PHP 的常规比较规则进行的。
<?php // 整数 echo 1 <=> '1'; // 0 echo 1 <=> 2; // -1 echo 2 <=> 1; // 1 // 浮点数 echo '1.50' <=> 1.5; // 0 echo 1.5 <=> 2.5; // -1 echo 2.5 <=> 1.5; // 1 // 字符串 echo "a" <=> "a"; // 0 echo "a" <=> "b"; // -1 echo "b" <=> "a"; // 1 ?>
Array 类型的常量现在可以通过 define() 来定义。在 PHP5.6 中仅能通过 const 定义。
define('ANIMALS', [ 'dog', 'cat', 'bird' ]); echo ANIMALS[1]; // 输出 "cat"
Closure::call() 现在有着更好的性能,简短干练的暂时绑定一个方法到对象上闭包并调用它。
<?php class A {private $x = 1;} // PHP 7 之前版本的代码 $getXCB = function() {return $this->x;}; $getX = $getXCB->bindTo(new A, 'A'); // 中间层闭包 echo $getX(); // PHP 7+ 及更高版本的代码 $getX = function() {return $this->x;}; echo $getX->call(new A);
以上例程会输出:
1
use
<?php // PHP 7 之前的代码 use some\namespace\ClassA; use some\namespace\ClassB; use some\namespace\ClassC as C; use function some\namespace\fn_a; use function some\namespace\fn_b; use function some\namespace\fn_c; use const some\namespace\ConstA; use const some\namespace\ConstB; use const some\namespace\ConstC; // PHP 7+ 及更高版本的代码 use some\namespace\{ClassA, ClassB, ClassC as C}; use function some\namespace\{fn_a, fn_b, fn_c}; use const some\namespace\{ConstA, ConstB, ConstC}; ?>위 루틴은 다음을 출력합니다:
<?php function testReturn(): ?string { return 'elePHPant'; } var_dump(testReturn()); function testReturn(): ?string { return null; } var_dump(testReturn()); function test(?string $name) { var_dump($name); } test('elePHPant'); test(null); test();매개변수 확장을 위해
...
연산자 사용string(10) "elePHPant" NULL string(10) "elePHPant" NULL Uncaught Error: Too few arguments to function test(), 0 passed in...위 루틴은 다음을 출력합니다.
<?php function swap(&$left, &$right) : void { if ($left === $right) { return; } $tmp = $left; $left = $right; $right = $tmp; } $a = 1; $b = 2; var_dump(swap($a, $b), $a, $b);
use 연산자가 확장되어 클래스에서 외부 함수 및 상수 가져오기를 지원합니다. 해당 구조는 use function과 use const입니다.
null int(2) int(1)
<?php $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 }
2. PHP 5.6.x에서 PHP 7.0.x
<?php class ConstDemo { const PUBLIC_CONST_A = 1; public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; }위 루틴은 다음을 출력합니다.
<?php function iterator(iterable $iter) : iterable { foreach ($iter as $val) { // } }반환 값 유형 선언
<?php try { // some code } catch (FirstException | SecondException $e) { // handle first and second exceptions }🎜🎜null 병합 연산자🎜🎜🎜일상적으로 삼항 표현식과 isset()을 동시에 사용하는 상황이 많아 null 병합 연산자(
??
) 구문을 추가했습니다. 설탕. 변수가 존재하고 NULL이 아니면 자체 값을 반환하고, 그렇지 않으면 두 번째 피연산자를 반환합니다. 🎜<?php $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 }🎜🎜우주선 연산자(조합 비교 연산자)🎜🎜🎜우주선 연산자는 두 식을 비교하는 데 사용됩니다. $a가 각각 $b보다 작거나 같거나 클 경우 -1, 0 또는 1을 반환합니다. 비교 원칙은 PHP의 일반 비교 규칙을 따릅니다. 🎜
<?php function test(object $obj) : object { return new SplQueue(); } test(new StdClass());🎜🎜define()을 통해 상수 배열 정의 🎜🎜🎜이제 Define()을 통해 Array 유형의 상수를 정의할 수 있습니다. PHP5.6에서는 const를 통해서만 정의할 수 있습니다. 🎜
abstract class A { abstract function test(string $s); } abstract class B extends A { // overridden - still maintaining contravariance for parameters and covariance for return abstract function test($s) : int; }🎜🎜Closure::call()🎜🎜🎜Closure::call()은 이제 더 나은 성능을 제공하며, 메서드를 객체의 클로저에 일시적으로 바인딩하고 호출하는 짧고 간결한 방법입니다. 🎜
interface A { public function Test(array $input); } class B implements A { public function Test($input){} // type omitted for $input }🎜위 루틴은 다음을 출력합니다. 🎜
use Foo\Bar\{ Foo, Bar, Baz, };🎜🎜그룹
use
선언🎜🎜🎜이제 동일한 네임스페이스에서 가져온 클래스, 함수 및 상수를 단일 use 문을 통해 한 번에 가져올 수 있습니다. 🎜rrreee🎜🎜생성기는 표현식을 반환할 수 있습니다🎜🎜🎜이 기능은 PHP 5.5 버전에 도입된 생성기 기능을 기반으로 합니다. 생성기 함수의 반환 구문을 사용하여 표현식을 반환할 수 있지만 참조 값의 반환은 허용되지 않습니다. Generator::getReturn() 메서드를 호출하여 생성기의 반환 값을 얻을 수 있습니다. 이 메서드는 생성할 때만 사용할 수 있습니다. 생성기가 작업 생성을 마친 후 한 번 호출됩니다. 🎜🎜🎜정수 나누기 함수 intp()🎜🎜🎜🎜🎜 PHP 7.0에서 이식되었습니다. 비어 있도록 하려면 앞에 물음표를 추가하세요. 이 기능이 활성화되면 전달된 매개변수 또는 함수에서 반환된 결과는 지정된 유형이거나 null 입니다. 🎜rrreee🎜위 루틴은 다음을 출력합니다. 🎜rrreee🎜🎜Void 함수🎜🎜🎜새로운 반환 값 유형 void가 도입되었습니다. 반환 값이 void 유형으로 선언된 메서드는 return 문을 모두 생략하거나 빈 return 문을 사용합니다. NULL은 void 함수에 대한 합법적인 반환 값이 아닙니다. 🎜rrreee🎜위 루틴은 다음을 출력합니다. 🎜rrreee🎜🎜Symmetric array destructuring🎜🎜🎜짧은 배열 구문([])은 이제 list() 구문의 대안이며 배열 값을 일부에 할당하는 데 사용할 수 있습니다. 변수(foreach 포함). 🎜rrreee🎜🎜클래스 상수 가시성🎜🎜🎜이제 클래스 상수의 가시성 설정을 지원합니다. 🎜<?php class ConstDemo { const PUBLIC_CONST_A = 1; public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; }
现在引入了一个新的被称为iterable的伪类 (与callable类似)。 这可以被用在参数或者返回值类型中,它代表接受数组或者实现了Traversable接口的对象。 至于子类,当用作参数时,子类可以收紧父类的iterable类型到array 或一个实现了Traversable的对象。对于返回值,子类可以拓宽父类的 array或对象返回值类型到iterable。
<?php function iterator(iterable $iter) : iterable { foreach ($iter as $val) { // } }
一个catch语句块现在可以通过管道字符(|)来实现多个异常的捕获。 这对于需要同时处理来自不同类的不同异常时很有用。
<?php try { // some code } catch (FirstException | SecondException $e) { // handle first and second exceptions }
list()
现在支持键名现在list()和它的新的[]语法支持在它内部去指定键名。这意味着它可以将任意类型的数组 都赋值给一些变量(与短数组语法类似)
<?php $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 }
从PHP 7.1.x 移植到 PHP 7.2.x
这种新的对象类型, object, 引进了可用于逆变(contravariant)参数输入和协变(covariant)返回任何对象类型。
<?php function test(object $obj) : object { return new SplQueue(); } test(new StdClass());
当一个抽象类继承于另外一个抽象类的时候,继承后的抽象类可以重写被继承的抽象类的抽象方法。
abstract class A { abstract function test(string $s); } abstract class B extends A { // overridden - still maintaining contravariance for parameters and covariance for return abstract function test($s) : int; }
重写方法和接口实现的参数类型现在可以省略了。不过这仍然是符合LSP,因为现在这种参数类型是逆变的。
interface A { public function Test(array $input); } class B implements A { public function Test($input){} // type omitted for $input }
命名空间可以在PHP 7中使用尾随逗号进行分组引入。
use Foo\Bar\{ Foo, Bar, Baz, };
위 내용은 PHP5.5 ~ PHP7.2의 새로운 기능 정리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!