PHP 8.1 现已推出,它附带了新功能和性能改进——最令人兴奋的是新的 JIT 编译器。它最近于 2021 年 11 月 25 日发布。
我将详细演示 PHP 8.1 提供的 10 大特性,以便您可以开始在您的项目中使用它们,并改善您的 PHP 体验。初学者和有经验的开发人员可以从本文中受益。
PHP 8.1 提供的 10 大功能
1、枚举
2、Fiber(纤维)
3、never返回类型
4、readonly属性
5、final类常量
6、新的array_is_list()函数
7、新的fsync()和fdatasync()函数
8、对字符串键数组解包的支持
9、$_FILES新的用于目录上传的full_path键
10、新的IntlDatePatternGenerator类
1. 枚举
PHP 8.1 添加了对枚举的支持,简写为enum。它是一种逐项类型,包含固定数量的可能值。请参阅以下代码片段以了解如何使用枚举。
<?php/***Declareanenumeration.*Itcanalsocontainanoptional'string'or'int'value.ThisiscalledbackedEnum.*Backedenums(ifused)shouldmatchthefollowingcriteria:*-Declarethescalartype,whetherstringorint,intheEnumdeclaration.*-Allcaseshavevalues.*-Allcasescontainthesamescalartype,whetherstringorint.*-Eachcasehasauniquevalue.*/enumUserRole:string{caseADMIN='1';caseGUEST='2';caseWRITER='3';caseEDITOR='4';}/***Youcanaccessacasebyusing*the'::'scoperesolutionoperator.*And,togetthenameoftheenumcase,you*canusethe'->'followedbytheattribute'name'.*/echoUserRole::WRITER->name;/***Togetthevalueoftheenumcase,youcan*usethe'->'followedbytheattribute'value'.*/echoUserRole::WRITER->value;?>
2. Fiber(纤维)
PHP 8.1 添加了对Fiber的支持,这是一个低级组件,允许在 PHP 中执行并发代码。Fiber 是一个代码块,它包含自己的变量和状态堆栈。这些 Fiber 可以被视为应用程序线程,可以从主程序启动。一旦启动,主程序将无法挂起或终止 Fiber。它只能从 Fiber 代码块内部暂停或终止。在 Fiber 挂起后,控制权再次返回到主程序,它可以从挂起的点继续执行 Fiber。
Fiber 本身不允许同时执行多个 Fiber 或主线程和一个 Fiber。但是,对于 PHP 框架来说,高效管理执行堆栈并允许异步执行是一个巨大的优势。
请参阅以下代码片段以了解如何使用 Fiber。
<?php/***InitializetheFiber.*/$fiber=newFiber(function():void{/***PrintsomemessagefrominsidetheFiber.*BeforetheFibergetssuspended.*/echo"WelcometoFiber!\\n";/***SuspendtheFiber.*/Fiber::suspend();/***PrintsomemessagefrominsidetheFiber.*AftertheFibergetsresumed.*/echo"WelcomebacktoFiber!\\n";});/***PrintamessagebeforestartingaFiber.*/echo"StartingaFiber\\n";/***StarttheFiber.*/$fiber->start();/***Fiberhasbeensuspenedfromtheinside.*Printsomemessage,andthenresumetheFiber.*/echo"Fiberhasbeensuspended\\n";echo"ResumingtheFiber\\n";/***ResumetheFiber.*/$fiber->resume();/***Endoftheexample.*/echo"Fibercompletedexecution\\n";?>
3.never返回类型
PHP 8.1 添加了名为never的返回类型。该never类型可用于指示函数将在执行一组指定的任务后终止程序执行。这可以通过抛出异常、调用exit()或die()函数来完成。
never返回类型类似于void返回类型。但是,void返回类型在函数完成一组指定的任务后继续执行。
请参阅以下代码片段以了解如何使用 never 返回类型。
<?php/***RouteClass*/classRoute{/***Constructoroftheclass*@returnvoid*/publicfunction__construct(){}/***RedirectToaPage*ThisfunctionredirectstoanURLspecifiedbytheuser.*@methodredirect()*@paramstring$url*@paraminteger$httpCode*@authorTaraPrasadRoutray<someemailaddress@example.com>*@accesspublic*@returnnever*/publicstaticfunctionredirect($url,$httpCode=301):never{/***RedirecttotheURLspecified.*/header("Location:{$url}",true,$httpCode);die;}}Route::redirect('https://www.google.com');?>
4.readonly属性
PHP 8.1 添加了名为readonly的类属性。已声明为只读的类属性只能初始化一次。里面设置的值不能改变。如果尝试强行更新该值,应用程序将抛出错误。请参阅以下代码片段以了解如何使用只读属性。
<?php/***UserClass*/classUser{/***Declareavariablewithreadonlyproperty.*@var$authUserID*@accesspublic*/publicreadonlyint$authUserID;/***Constructoroftheclass.*@paraminteger$userID*@returnvoid*/publicfunction__construct($userID){/***Changethevalueofthepropertyasspecified.*Updatingthevalueofreadonlypropertiesare*allowedonlythroughtheconstructor.*/$this->authUserID=$userID;}/***UpdateAuthUserID*Thisfunctiontriestoupdatethereadonlyproperty(whichisnotallowed).*@methodupdateAuthUserID()*@paraminteger$userID*@authorTaraPrasadRoutray<someemailaddress@example.com>*@accesspublic*@returnvoid*/publicfunctionupdateAuthUserID($userID){/***Changethevalueofthepropertyasspecified.*Executingthisfunctionwillthrowthefollowingerror;*PHPFatalerror:UncaughtError:CannotmodifyreadonlypropertyUser::$authUserID*/$this->authUserID=$userID;}}/***Initializetheclassandupdatethevalueofthereadonlyproperty.*/$user=newUser(30);/***Printthereadonlypropertyvalue.*Thiswillprint30.*/echo$user->authUserID;/***Callanotherfunctioninsidetheclassandtrytoupdatetheclassproperty.*/$user->updateAuthUserID(50);/***Printthereadonlypropertyvalue.*/echo$user->authUserID;?>
5.final类常量
PHP 8.1 添加了对名为final的类常量的支持。最终类常量不能被修改,即使是通过继承,这意味着它们不能被子类扩展或覆盖。
这个标志不能用于私有常量,因为它不能在类之外被访问。声明 final 和 private 常量将导致致命错误。
请参阅以下代码片段以了解如何使用最终标志。
<?php/***UserRoleClass*/classUserRole{/***Declareafinalclassconstantwithavalue.*/finalpublicconstADMIN='1';}/***UserClassextendingtheUserRoleClass*/classUserextendsUserRole{/***Declareanotherconstantwiththesamename*asoftheparentclasstooverridethevalue.**Note:Overridingthevaluewillthrowthefollowingerror:*PHPFatalerror:User::ADMINcannotoverridefinalconstantUserRole::ADMIN*/publicconstADMIN='2';}?>
6. 新的array_is_list()函数
PHP 8.1 添加了名为array_is_list()的数组函数。它标识指定的数组是否具有从 0 开始的所有连续整数。如果数组是值的语义列表(一个数组,其键从 0 开始,都是整数,并且之间没有间隙),则此函数返回 true。对于空数组,它也返回 true。请参阅以下代码片段以了解如何使用 array_is_list() 函数。
<?php/***Returnstrueforemptyarray.*/array_is_list([]);/***Returnstrueforsequentialsetofkeys.*/array_is_list([1,2,3]);/***Returnstrueasthefirstkeyiszero,andkeysareinsequentialorder.*Itissameas[0=>'apple',1=>2,2=>3]*/array_is_list(['apple',2,3]);/***Returnstrueasthefirstkeyiszero,andkeysareinsequentialorder.*Itissameas[0=>'apple',1=>'scissor']*/array_is_list(['apple','orange']);/***Returnstrueasthefirstkeyiszero,andkeysareinsequentialorder.*Itissameas[0=>'apple',1=>'scissor']*/array_is_list([0=>'apple','orange']);/***Returnstrueasthefirstkeyiszero,andkeysareinsequentialorder.*/array_is_list([0=>'rock',1=>'scissor']);?>
键不是从 0 开始的数组,或者键不是整数,或者键是整数但不按顺序出现的数组将评估为 false。
<?php/***Returnsfalseasthefirstkeydoesnotstartfromzero.*/array_is_list([1=>'apple','orange']);/***Returnsfalseasthefirstkeydoesnotstartfromzero.*/array_is_list([1=>'apple',0=>'orange']);/***Returnsfalseasallkeysarenotinteger.*/array_is_list([0=>'apple','fruit'=>'orange']);/***Returnsfalseasthekeysarenotinsequentialorder.*/array_is_list([0=>'apple',2=>'orange']);?>
7. 新的fsync()和fdatasync()函数
PHP 8.1 添加了对fsync()和fdatasync()函数的支持。两者都与现有fflush()函数有相似之处,该函数当前用于将缓冲区刷新到操作系统中。然而,fsync()和fdatasync()刷新该缓冲区到物理存储。它们之间的唯一区别是该fsync()函数在同步文件更改时包含元数据,而该fdatasync()函数不包含元数据。
fsync()函数将采用文件指针并尝试将更改提交到磁盘。成功时返回 true,失败时返回 false,如果资源不是文件,则会发出警告。fdatasync()函数的工作方式相同,但速度稍快一些,因为 fsync() 将尝试完全同步文件的数据更改和有关文件的元数据(上次修改时间等),这在技术上是两次磁盘写入。
请参阅以下代码片段以了解如何使用 fsync() 和 fdatasync() 函数。
<?php/***Declareavariableandassignafilename.*/$fileName='notes.txt';/***Createthefilewithreadandwritepermission.*/$file=fopen($fileName,'w+');/***Addsometextintothefile.*/fwrite($file,'Paragraph1');/***Addalinebreakintothefile.*/fwrite($file,"\\r\\n");/***Addsomemoretextintothefile.*/fwrite($file,'Paragraph2');/***Youcanuseboththefsync()orfdatasync()functions*tocommitchangstodisk.*/fsync($file);//orfdatasync($file)./***Closetheopenfilepointer.*/fclose($file);?>
8. 对字符串键数组解包的支持
PHP 8.1 添加了对字符串键数组解包的支持。为了解压数组,PHP 使用展开(…)运算符。PHP 7.4 中引入了这个运算符来合并两个或多个数组,但语法更简洁。但在 PHP 8.1 之前,展开运算符仅支持带数字键的数组。请参阅以下代码片段以了解如何将展开运算符用于字符串键控数组。
<?php/***Declareanarray*/$fruits1=['JonathanApples','Sapote'];/***Declareanotherarray*/$fruits2=['Pomelo','Jackfruit'];/***Mergeabovetwoarraysusingarrayunpacking.*/$unpackedFruits=[…$fruits1,…$fruits2,…['RedDelicious']];/***Printtheaboveunpackedarray.*Thiswillprint:*array(5){*[0]=>*string(15)"JonathanApples"*[1]=>*string(6)"Sapote"*[2]=>*string(6)"Pomelo"*[3]=>*string(9)"Jackfruit"*[4]=>*string(13)"RedDelicious"*}*/var_dump($unpackedFruits);?>
9.$_FILES新的用于目录上传的full_path键
PHP 8.1 添加了对$_FILES全局变量中full_path新键的支持。在 PHP 8.1 之前,$_FILES没有存储到服务器的相对路径或确切目录。因此,您无法使用 HTML 文件上传表单上传整个目录。新full_path键解决了这个问题。它存储相对路径并在服务器上重建确切的目录结构,使目录上传成为可能。请参阅以下代码片段以了解如何将full_path键与$_FILES全局变量一起使用。
<?php/***Checkiftheuserhassubmittedtheform.*/if($_SERVER['REQUEST_METHOD']==='POST'){/***Printthe$_FILESglobalvariable.Thiswilldisplaythefollowing:*array(1){*["myfiles"]=>array(6){*["name"]=>array(2){*[0]=>string(9)"image.png"*[1]=>string(9)"image.png"*}*["full_path"]=>array(2){*[0]=>string(25)"folder1/folder2/image.png"*[1]=>string(25)"folder3/folder4/image.png"*}*["tmp_name"]=>array(2){*[0]=>string(14)"/tmp/phpV1J3EM"*[1]=>string(14)"/tmp/phpzBmAkT"*}*//…+error,type,size*}*}*/var_dump($_FILES);}?><formaction=""method="POST"enctype="multipart/form-data"><inputname="myfiles[]"type="file"webkitdirectorymultiple/><buttontype="submit">Submit</button></form>
10. 新的IntlDatePatternGenerator类
PHP 8.1 添加了对新IntlDatePatternGenerator类的支持。在 PHP 8.1 之前,只能使用IntlDateFormatter。虽然它支持昨天、今天和明天使用的八种预定义格式,但是这些格式和IntlDatePatternGenerator不太一样。这个类允许指定日期、月份和时间的格式,并且顺序将由类自动处理。请参阅以下代码片段以了解如何使用 IntlDatePatternGenerator 类。
<?php/***Defineadefaultdateformat.*/$skeleton="YYYY-MM-dd";/***Parseatimestring(fortoday)accordingtoaspecifiedformat.*/$today=\\DateTimeImmutable::createFromFormat('Y-m-d',date('Y-m-d'));/***===========================*PRINTINGDATEINUSAFORMAT*===========================*InitiateaninstancefortheIntlDatePatternGeneratorclass*andprovidethelocaleinformation.*Inthebelowexample,I'veusedlocale:en_US.*/$intlDatePatternGenerator=new\\IntlDatePatternGenerator("en_US");/***Getthecorrectdateformatforthelocale:en_US.*Followingfunction"getBestPattern"willreturn:*MM/dd/YYYY*/$enUSDatePattern=$intlDatePatternGenerator->getBestPattern($skeleton);/***Usethe"formatObject"functionofIntlDateFormattertoprintasperspecifiedpattern.*Thiswillprintthefollowing:*Dateinen-US:12/03/2021*/echo"Dateinen-US:".\\IntlDateFormatter::formatObject($today,$enUSDatePattern,"en_US")."\\n";/***=============================*PRINTINGDATEININDIAFORMAT*=============================*InitiateaninstancefortheIntlDatePatternGeneratorclass*andprovidethelocaleinformation.*Inthebelowexample,I'veusedlocale:en_IN.*/$intlDatePatternGenerator=new\\IntlDatePatternGenerator("en_IN");/***Getthecorrectdateformatforthelocale:en_IN.*Followingfunction"getBestPattern"willreturn:*dd/MM/YYYY*/$enINDatePattern=$intlDatePatternGenerator->getBestPattern($skeleton);/***Usethe"formatObject"functionofIntlDateFormattertoprintasperspecifiedpattern.*Thiswillprintthefollowing:*Dateinen-IN:03/12/2021*/echo"Dateinen-IN:".\\IntlDateFormatter::formatObject($today,$enINDatePattern,"en_IN")."\\n";?>
点赞!您已经完成了 PHP 8.1 提供的功能的学习。现在您可以继续并开始在您当前或即将进行的项目中实现上述功能。
原文:https://levelup.gitconnected.com/top-10-php-8-1-features-you-should-start-using-now-7161b91275fd
产品猿社区致力收录更多优质的商业产品,给服务商以及软件采购客户提供更多优质的软件产品,帮助开发者变现来实现多方共赢;
日常运营的过程中我们难免会遇到各种版权纠纷等问题,如果您在社区内发现有您的产品未经您授权而被用户提供下载或使用,您可按照我们投诉流程处理,点我投诉;
本文来自用户发布投稿,不代表产品猿立场 ;若对此文有疑问或内容有严重错误,可联系平台客服反馈;
部分产品是用户投稿,可能本文没有提供官方下下载地址或教程,若您看到的内容没有下载入口,您可以在我们产品园商城搜索看开发者是否有发布商品;若您是开发者,也诚邀您入驻商城平台发布的产品,地址:点我进入;
如若转载,请注明出处:https://www.chanpinyuan.cn/40043.html;