>  기사  >  백엔드 개발  >  PHP7의 새로운 기능은 무엇입니까? php7의 일반적인 새로운 기능 편집

PHP7의 새로운 기능은 무엇입니까? php7의 일반적인 새로운 기능 편집

不言
不言원래의
2018-08-08 16:39:204236검색

기본 엔진의 코드 대부분이 PHP7에서 수정되었고, 다양한 방법을 통해 PHP의 성능이 향상되었기 때문에 일부 새로운 구문도 PHP7에 추가되었습니다. 이러한 구문을 사용하면 성능 향상에도 도움이 될 수 있습니다. php7에서 일반적으로 사용되는 새로운 기능을 정리해 보겠습니다.

1, ??연산자(NULL 합체 연산자)

이것이 매우 유용하다고 생각해서 먼저 넣었습니다. 사용법:

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

이는 다음과 같습니다:

<?php
$a = isset($_GET[&#39;a&#39;]) ? $_GET[&#39;a&#39;] : 1;

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

$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]));

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

这种声明的写法有些类似于 swift:

func sayHello(personName: String) -> String {
    let greeting = "Hello, " + personName + "!"
    return greeting
}

这个特性可以帮助我们避免一些 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

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

是不是有点类似与 js 的 strict mode?

3、标量类型声明

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

官方示例:

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

var_dump(sumOfInts(2, '3', 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 *rrreee

From 이 예에서 볼 수 있듯이 이제 함수(익명 함수 포함)에서 반환 값의 유형을 지정할 수 있습니다.

이 선언의 작성은 Swift와 다소 유사합니다.

rrreee

이 기능은 PHP의 암시적 유형 변환으로 인해 발생하는 일부 문제를 피하는 데 도움이 될 수 있습니다. 함수를 정의하기 전에 예상되는 결과를 생각하면 불필요한 실수를 피할 수 있습니다.

하지만 여기서 주의가 필요한 기능도 있습니다. PHP 7에는 엄격 모드를 사용하는 declare 지시문인 strict_types가 추가되었습니다.

반환 값 유형 선언을 사용할 때 엄격 모드에서 선언되지 않은 경우, 반환 값이 예상 유형이 아닌 경우 PHP는 이에 대해 캐스트 유형 변환을 계속 수행합니다. 그러나 엄격 모드인 경우 TypeError의 치명적인 오류가 발생합니다.

Force 모드:

rrreee

위 코드는 정상적으로 실행될 수 있으며 foo 함수는 오류 없이 int 1을 반환합니다.

엄격 모드:

rrreee

선언 후에는 치명적인 오류가 발생합니다.

js의 strict 모드와 비슷한가요?

3. 스칼라 유형 선언

PHP 7에서 함수의 공식적인 매개변수 유형 선언은 이제 스칼라일 수 있습니다. PHP 5에서는 클래스 이름, 인터페이스, 배열 또는 호출 가능만 가능합니다(PHP 5.4에서는 이제 익명 함수를 포함한 함수일 수 있음). string, int, floatbool을 사용할 수도 있습니다.

공식 예:

rrreee 위에서 언급한 엄격 모드 문제는 여기에도 적용됩니다. 필수 모드(기본값, 강제 유형 변환)에서는 기대치를 충족하지 않는 매개변수가 여전히 강제로 입력됩니다. 엄격 모드에서는 TypeError라는 치명적인 오류가 발생합니다.

🎜4. 일괄 선언 사용🎜🎜🎜PHP 7에서는 한 문장으로 여러 클래스나 함수 또는 const를 선언할 수 있습니다. 🎜rrreee🎜하지만 여전히 각 클래스나 함수 또는 const의 이름을 작성해야 합니다. Python의 from some import * 메소드와 같습니다). 🎜🎜주의해야 할 질문은: 작곡가와 PSR-4 기반 프레임워크를 사용하는 경우 이 작성 방법으로 클래스 파일을 성공적으로 로드할 수 있습니까? 실제로는 가능합니다. 작곡가가 등록한 자동 로딩 메소드는 클래스 호출 시 클래스의 네임스페이스에 따라 위치를 검색합니다. 🎜🎜위의 새로운 기능 외에도 몇 가지를 간략하게 언급하겠습니다. 🎜🎜PHP 5.3에는 익명 함수가 포함되었으며 이제 익명 클래스가 있습니다. 🎜🎜define은 이제 상수 배열을 정의할 수 있습니다. 🎜🎜Closure(클로저)는 다음과 같습니다. 호출 메서드가 추가되었습니다. 🎜🎜생성기(또는 반복자가 더 적절하게 호출됨)는 최종 반환 값(return)을 가질 수도 있고, 새로운 생성자(yield from) 구문을 통해 다른 생성기(생성기 대리자)를 입력할 수도 있습니다. 🎜🎜제너레이터의 두 가지 새로운 기능(return 및 Yield from)을 결합할 수 있습니다. 구체적인 외관을 직접 테스트할 수 있습니다. PHP 7은 현재 RC5에 있으며 최종 버전은 곧 출시될 예정입니다. 🎜🎜 추천 관련 기사: 🎜🎜🎜 PHP7의 새로운 기능 소개🎜🎜🎜🎜🎜 php7의 주요 새로운 기능에 대한 간략한 이야기, php7에 대한 간략한 이야기🎜🎜🎜🎜🎜[번역] PHP7 소개: 새로운 기능 및 제거된 기능🎜🎜

위 내용은 PHP7의 새로운 기능은 무엇입니까? php7의 일반적인 새로운 기능 편집의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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