>  기사  >  백엔드 개발  >  php7의 새로운 스칼라, 연산자 및 반환 값 유형 기능에 대한 자세한 설명

php7의 새로운 스칼라, 연산자 및 반환 값 유형 기능에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-06-27 10:19:571345검색

1. ?? 연산자(NULL 병합 연산자)

$a = $_GET['a'] ?? 1;

다음과 동일합니다:

$a = empty($_GET['a']) ? 1 : $_GET['a'];

우리는 삼항 연산자연산자가 다음과 같이 사용될 수 있다는 것을 알고 있습니다:

$a ?: 1

그러나 이것은 이미 $a를 기반으로 합니다. 정의된 전제에 따라. 새로운 ?? 연산자는 판단을 단순화할 수 있습니다. 코드가 단순화되면서 동시에 더욱 직관적이 되었습니다!

2. 함수 반환 값 유형 선언

공식 문서에서 제공하는 예(...의 측면 길이 매개변수 구문은 PHP 5.6 이상에서만 사용 가능): ... 的边长参数语法在 PHP 5.6 以上的版本中才有):

<?php
function arraysSum(array ...$arrays): array
{
    return array_map(function(array $array): int {
        return array_sum($array);
    }, $arrays);
}

print_r(arraysSum([1,2,3], [4,5,6], [7,8,9]));

从这个例子中可以看出现在函数(包括匿名函数)都可以指定返回值的类型。

这个特性可以帮助我们避免一些 PHP 的隐式类型转换带来的问题。在定义一个函数之前就想好预期的结果可以避免一些不必要的错误。

不过这里也有一个特点需要注意。PHP 7 增加了一个 declare 指令:strict_types,既使用严格模式。

使用返回值类型声明时,如果没有声明为严格模式,如果返回值不是预期的类型,PHP 还是会对其进行强制类型转换。但是如果是严格模式, 则会出发一个 TypeError 的 Fatal error。

强制模式:

<?php
function foo($a) : int
{
    return $a;
}

foo(1.0);

以上代码可以正常执行,foo 函数返回 int 1,没有任何错误。

严格模式:

<?php
declare(strict_types=1);

function foo($a) : int
{
    return $a;
}

foo(1.0);

在声明之后,就会触发致命错误。

# PHP Fatal error:  Uncaught TypeError: Return value of foo() must be of the type integer, float returned in test.php:6

3. 标量类型声明

PHP 7 中的函数的形参类型声明可以是标量了。在 PHP 5 中只能是类名、接口、array 或者 callable (PHP 5.4,即可以是函数,包括匿名函数),现在也可以使用 stringintfloat和 bool 了。

<?php
// Coercive mode
function sumOfInts(int ...$ints)
{
    return array_sum($ints);
}

var_dump(sumOfInts(2, &#39;3&#39;, 4.1));

需要注意的是上文提到的严格模式的问题在这里同样适用:强制模式(默认,既强制类型转换)下还是会对不符合预期的参数进行强制类型转换,严格模式下则触发 TypeError 的致命错误。

4. use 批量声明

PHP 7 中 use 可以在一句话中声明多个类或函数或 const 了:

<?php
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};

但还是要写出每个类或函数或 const 的名称(并没有像 python 一样的 from some import * 的方法)。

需要留意的问题是:如果你使用的是基于 composer 和 PSR-4 的框架,这种写法是否能成功的加载类文件?其实是可以的,composer 注册的自动加载方法是在类被调用的时候根据类的命名空间去查找位置,这种写法对其没有影响。

再来简单说几个:

1、PHP 5.3 开始有了匿名函数,现在又有了匿名类了;

2、define 现在可以定义常量数组;

3、闭包( Closure)增加了一个 call 方法;

4、生成器(或者叫迭代器更合适)可以有一个最终返回值(return),也可以通过 yield from 的新语法进入一个另外一个生成器中(生成器委托)。

生成器的两个新特性(return 和 yield fromrrreee

From 이 예에서는 모든 함수(익명 함수🎜 포함)가 반환 값의 유형을 지정할 수 있음을 알 수 있습니다. 🎜🎜이 기능은 PHP의 암시적인 유형 변환🎜 질문 중 일부를 피하는 데 도움이 될 수 있습니다. 함수를 정의🎜하기 전에 예상되는 결과를 생각하면 불필요한 오류를 피할 수 있습니다. 🎜🎜하지만 여기서 주의가 필요한 기능도 있습니다. PHP 7에는 엄격 모드를 사용하는 declare 지시문인 strict_types가 추가되었습니다. 🎜🎜반환 값 유형 선언을 사용할 때 엄격 모드에서 선언되지 않은 경우, 반환 값이 예상 유형이 아닌 경우 PHP는 이에 대해 캐스트 유형 변환을 계속 수행합니다. 그러나 엄격 모드인 경우 TypeError의 치명적인 오류가 발생합니다. 🎜🎜Force 모드: 🎜rrreee🎜위 코드는 정상적으로 실행될 수 있으며 foo 함수는 오류 없이 int 1을 반환합니다. 🎜🎜엄격 모드: 🎜rrreee🎜선언 후에는 치명적인 오류가 발생합니다. 🎜rrreee🎜3. 스칼라 유형 선언🎜🎜PHP 7에서 함수의 공식적인 매개변수 유형 선언은 스칼라일 수 있습니다. PHP 5에서는 클래스 이름, 인터페이스, 배열 또는 호출 가능만 가능합니다(PHP 5.4에서는 익명 함수를 포함한 함수일 수도 있습니다). 문자열, int, floatbool을 사용하세요. 🎜rrreee🎜 위에서 언급한 엄격 모드 문제는 여기에도 적용됩니다. 강제 모드(기본값은 강제 유형 변환)에서는 엄격 모드에서 기대치를 충족하지 않는 매개변수에 대해 강제 유형 변환이 계속 수행됩니다. , TypeError의 치명적인 오류가 발생합니다. 🎜🎜4. 일괄 선언 사용🎜🎜PHP 7에서는 여러 클래스나 함수 또는 const를 한 문장으로 선언할 수 있습니다. 🎜rrreee🎜하지만 여전히 각 클래스나 함수 또는 const의 이름을 작성해야 합니다(파이썬과는 다릅니다. 일부 import * 메소드와 동일). 🎜🎜주의해야 할 질문은: 작곡가와 PSR-4 기반 프레임워크를 사용하는 경우 이 작성 방법으로 클래스 파일을 성공적으로 로드할 수 있습니까? 실제로는 Composer가 등록한 자동 로딩 방식은 클래스가 있을 때 가능합니다. 이 작성 방법은 클래스의 네임스페이스 🎜에 따라 위치를 찾습니다. . 🎜🎜몇 가지 더 간략하게 이야기해 보겠습니다. 🎜🎜1. PHP 5.3에는 익명 클래스가 있습니다. 🎜🎜2. 이제 상수 배열을 정의할 수 있습니다. 🎜🎜3. 🎜🎜4. 생성기(또는 반복자가 더 적합함)는 최종 반환 값(return)을 갖거나 yield from(생성기 대리자)의 새로운 구문을 통해 다른 생성기를 입력할 수 있습니다. 🎜🎜생성기의 두 가지 새로운 기능(return 및 yield from)을 결합할 수 있습니다. 자세한 내용은 직접 테스트해 볼 수 있습니다. 🎜

위 내용은 php7의 새로운 스칼라, 연산자 및 반환 값 유형 기능에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.