PHP 7 值得期待的新特性(下)
这是我们期待已久的 PHP 7 系列文章的第二篇。点此阅读 第一篇本文系 OneAPM 工程师编译整理。
也许你已经知道,重头戏 PHP 7 的发布将在今年到来!现在,让我们来了解一下,新版本有哪些新功能与改进。
在本系列的 第一篇 ,我们介绍了 PHP 7 中最重要的一些不兼容性修复以及两大新特性。在本文中,我们将了解 PHP 7 的另外六大功能。
Unicode 代码点转义语法
新增加的转义字符?? \u,允许我们在 PHP 字符串内明确指定 Unicode 字符代码点(以十六进制):
此处使用的语法为 \u{CODEPOINT} 。例如这个绿色的心形,?, 可以表示为 PHP 字符串 __"\u{1F49A}"__。
Null 合并操作符
另一个新的操作符?? Null 合并操作符 ?? ,其实是传说中的三目运算符 。如果它不是 Null ,将返回左操作数,否则返回右操作数。
重点在于,如果左操作数是一个不存在的变量,也不会引起注意。这就像 isset() ,而不像 ?: 短三目运算符。
你还可以链接该操作符,从而返回给定集合的第一个非 null 值。
$config = $config ?? $this->config ?? static::$defaultConfig;
调用之上绑定闭包
之前,在 PHP 5.4 添加的 Closure->bindTo() 与 Closure::bind() 允许你改变 $this 和调用范围的绑定,同时或单独地,创建一个重复闭包。
现在,PHP 7 增加了在调用时达到上述功能的简便方法,通过 Closure->call() 将 $this 和调用范围绑定至同一对象 。该方法将对象作为首个参数,然后是传到闭包中的其他参数,如下:
class HelloWorld { private $greeting = "Hello";}$closure = function($whom) { echo $this->greeting . ' ' . $whom; }$obj = new HelloWorld();$closure->call($obj, 'World'); // Hello World
组使用声明
如果你曾经从同一命名空间导入多个类,而你的 IDE 能自动完成,你肯定会很高兴。对于其他人,为了简便起见,PHP 7 现在有了 组使用声明。这让你快速清楚地指定多次相似的 导入:
// Originaluse Framework\Component\SubComponent\ClassA;use Framework\Component\SubComponent\ClassB as ClassC;use Framework\Component\OtherComponent\ClassD;// With Group Useuse Framework\Component\{ SubComponent\ClassA, SubComponent\ClassB as ClassC, OtherComponent\ClassD};
你也可以在常量导入与函数导入时与 use function、use const 一起使用它。同时也支持混合导入。
use Framework\Component\{ SubComponent\ClassA, function OtherComponent\someFunction, const OtherComponent\SOME_CONSTANT};
生成器改进
生成器返回表达式生成器有两大新功能。首先是 生成器返回表达式,它允许你在生成器(成功)完成时返回一个值。
PHP 7 之前,如果你尝试返回任何值将导致错误。然而,现在你可以调用 $generator->getReturn() 来获取返回值。
如果生成器尚未返回,或抛出未捕获的异常,调用 $generator->getReturn() 将抛出一个异常。
如果生成器已完成,但没有返回,则返回空。
举例如下:
function gen() { yield "Hello"; yield " "; yield "World!"; return "Goodbye Moon!";}$gen = gen();foreach ($gen as $value) { echo $value; }// Outputs "Hello" on iteration 1, " " on iterator 2, and "World!" on iteration 3echo $gen->getReturn(); // Goodbye Moon!
第二个功能则更令人兴奋:生成器委托。这允许你返回另一个可迭代结构,它可以迭代自身??不论是数组,迭代器,还是另一个生成器。
重要的是,子结构的迭代是由最外层的原始循环完成的,如同单一的平面结构,而非递归结构。
当向生成器发送数据或异常时也同理。这些数据或异常会直接传到子结构中,就像被调用直接控制。
这是使用了
function hello() { yield "Hello"; yield " "; yield "World!"; yield from goodbye();}function goodbye() { yield "Goodbye"; yield " "; yield "Moon!";}$gen = hello();foreach ($gen as $value) { echo $value;}
在每次迭代中,将输出:
"Hello"
" "
"World!"
"Goodbye"
" "
"Moon!"
值得一提的一点警告是,由于子结构可以产生自己的键,多次迭代完全可能返回相同的键??如果这对你很重要,你需要自己想办法避免。
内部异常
在 PHP 中,致命和可捕获的致命错误一直无法处理,或者很难处理 。但有了内部异常 以后,许多这类错误现在都可以抛出异常了。
现在,当一个致命或可捕获的致命错误发生时,会抛出一个异常,允许你从容地处理它。如果你不进行处理,它将成为未捕获的异常这类传统的致命错误。
这些异常是 \EngineException 对象。它们不像所有的用户异常,并不继承自 \Exception 类。这是为了确保现在捕获 \Exception 类的代码今后不会开始捕获致命错误。从而保持向后兼容性。
在将来,如果你想同时捕获传统异常和内部异常,你需要捕获他们新的共享父类,\BaseException。
此外, eval()’ed 代码中的解析错误会抛出 \ParseException,而类型不匹配将抛出一个 \TypeException。
如下例:
try { nonExistentFunction();} catch (\EngineException $e) { var_dump($e);}object(EngineException)#1 (7) { ["message":protected]=> string(32) "Call to undefined function nonExistantFunction()" ["string":"BaseException":private]=> string(0) "" ["code":protected]=> int(1) ["file":protected]=> string(17) "engine-exceptions.php" ["line":protected]=> int(1) ["trace":"BaseException":private]=> array(0) { } ["previous":"BaseException":private]=> NULL}
OneAPM for PHP 能够深入到所有 PHP 应用内部完成应用性能管理 能够深入到所有 PHP 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。
即将到来!
距离 PHP 7.0.0 发布只有八个月了(译者翻译时所剩时日不多),该版本很可能是 PHP 历史上性能最快的一版。虽然现在它只具备内部测试品质(目前 RC5 已可以下载) ,但 PHP 7 的确让人期待。
并且,你能帮助它变得更好。
测试你的代码
使用 Rasmus’s 的 PHP 7 vagrant 沙盒,开始运行你的测试套件,或执行常规的质量检验。向项目报告错误,并定期重试。
帮助 GOPHP7-EXT
使用 PHP 7 的一大障碍是确保更新所有扩展使之与新的 Zend Engine 3 兼容。
如果你使用的扩展较为小众,没有得到其维护者足够的关注??或者你使用自己的扩展??请查看 GoPHP7-ext 项目从而确保 PHP 7 发布后一切都准备妥当。
书写文档
PHP 7 中的每个新功能都有一个 RFC 。你可以在 PHP.net 维基 找到他们,并在此基础上写新文档。你可以在 在线GUI 环境下 写,包括提交(如果你有 karma)或提交补丁以供审核。
总结
PHP 7 将是伟大的!
PHP是全世界最好的语言,没有之一 :)
抓紧测试你的应用程序。帮助迁移扩展。
P.S. 你已经在使用 PHP 7 了么?你对新功能有何感受?是否有你不满意,或者不喜欢的地方?你认为你会何时升级?让我们知道你的想法!
分享你的想法,尽在 APM俱乐部!
OneAPM for PHP 能够深入到所有 PHP 应用内部完成应用性能管理 能够深入到所有 PHP 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alipay PHP ...

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

세션 납치는 다음 단계를 통해 달성 할 수 있습니다. 1. 세션 ID를 얻으십시오. 2. 세션 ID 사용, 3. 세션을 활성 상태로 유지하십시오. PHP에서 세션 납치를 방지하는 방법에는 다음이 포함됩니다. 1. 세션 _regenerate_id () 함수를 사용하여 세션 ID를 재생산합니다. 2. 데이터베이스를 통해 세션 데이터를 저장하십시오.

PHP 개발에서 견고한 원칙의 적용에는 다음이 포함됩니다. 1. 단일 책임 원칙 (SRP) : 각 클래스는 하나의 기능 만 담당합니다. 2. Open and Close Principle (OCP) : 변경은 수정보다는 확장을 통해 달성됩니다. 3. Lisch의 대체 원칙 (LSP) : 서브 클래스는 프로그램 정확도에 영향을 미치지 않고 기본 클래스를 대체 할 수 있습니다. 4. 인터페이스 격리 원리 (ISP) : 의존성 및 사용되지 않은 방법을 피하기 위해 세밀한 인터페이스를 사용하십시오. 5. 의존성 반전 원리 (DIP) : 높고 낮은 수준의 모듈은 추상화에 의존하며 종속성 주입을 통해 구현됩니다.

phpstorm에서 CLI 모드를 디버그하는 방법은 무엇입니까? PHPStorm으로 개발할 때 때때로 CLI (Command Line Interface) 모드에서 PHP를 디버그해야합니다 ...

시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP 개발에서 PHP의 CURL 라이브러리를 사용하여 JSON 데이터를 보내면 종종 외부 API와 상호 작용해야합니다. 일반적인 방법 중 하나는 컬 라이브러리를 사용하여 게시물을 보내는 것입니다 ...
