php最新版本最多少_php最新稳定版本

php最新版本最多少_php最新稳定版本,第1张

php最新版本最多少_php最新稳定版本 PHP 团队于2020年11月26日宣布 PHP 8 正式发布!php8的下载地址:https://www.php.net/downloads.phpPHP 8.0.0 目前是最新的主要版本,它引入了一些重大变更,以及许多新特性和性能优化,PHP 8.0 值得关注的改进包括以下:1、PHP 8.0 引入了备受期待的 Just In Time (JIT) 编译器,能够进一步提高 PHP 脚本的执行速度2、PHP 8.0 合并了诸多性能优化3、JSON 支持现在被视为语言的核心部分,始终可用,而不是作为可选模块4、支持 named 参数,因为它们能够指定参数名称而不是其确切顺序5、支持类/属性/函数/方法/参数/常量的结构化元数据的属性(或在其他语言中也称为注释或修饰符)6、支持可以指示多种不同类型的联合类型,这些类型可以用作参数或函数的返回类型7、支持静态返回类型8、str_contains()函数是一种检查字符串是否包含在另一个字符串中的简便方法,而不必使用strpos等。

与之相似的是新的str_starts_with()和str_ends_with()函数9、添加了Nullsafe运算符,作为在方法上应用空合并行为的快速简便的方法10、相比较 PHP 7.4 稳定版,PHP 8.0 在性能上大约改进了 10%,但是至少在某些方面,JIT 可以提供更多的性能。

下面我们来看看新特性和性能优化新增 ValueError 异常这是8新引入进来的 ValueError 的内置异常类,它继承自 Exception 基类。

你每次传递值到函数时候,如果检测到是一个无效的类型时抛出该异常,在 PHP 8 之前,这样的 *** 作会直接做警告处理。

示例代码:<?phpdeclare(strict_types=1);/***传递数组到array_rand,类型正确,但是array_rand期望传入的是非空数组*所以会抛出ValueError异常*/array_rand([],0);/***json_decode的深度参数必须是有效的正整型值,*所以这里也会抛出ValueError异常*/json_decode('{}',true,-1);运行结果:新增对联合类型的支持8新增的联合类型,它允许一个变量拥有多个类型的值。

示例代码如下:<?phpdeclare(strict_types=1);/***定义一个支持联合类型的Number类*/classNumber{privateint|float$number;publicfunctionsetNumber(int|float$number):void{$this->number=$number;}publicfunctiongetNumber():int|float{return$this->number;}}/***我们可以传递浮点型和整型值到Number对象*/$number=newNumber();$number->setNumber(5);var_dump($number->getNumber());$number->setNumber(11.54);var_dump($number->getNumber());exit;运行结果:重写方法时允许可变参数当你在子类重写父类方法时,任何数量的参数都可以被替换成可变参数的,只要对应参数类型是兼容的就可以。

示例代码如下<?phpdeclare(strict_types=1);classA{publicfunctionmethod(int$many,string$parameters,$here){}}classBextendsA{publicfunctionmethod(...$everything){var_dump($everything);}}$b=newB();$b->method('icanbeoverwritten!');exit;运行结果:静态返回类型8 中可以使用 static 关键字标识某个方法,且返回该方法当前所属的类,即使它是继承的,可用于后期静态绑定。

示例代码如下:<?phpdeclare(strict_types=1);classTest{publicfunctiondoWhatever():static{//Dowhatever.return$this;}}exit;新增 WeakMap 特性WeakMap 允许你创建对象到任意值的映射(这个就类似 SplObjectStorage)的同时也不会阻止作为键的对象被垃圾回收。

要是某个对象键被垃圾回收了,对应键值对就会从集合中被移除。

这一新特性非常有用,开发者不必担心代码存在内存泄露了。

大多数 PHP 开发者可能对此不关心,但是当你在编写长时间运行的进程时,那你就一定要提防这个问题了,比如使用 ReactPHP 进行事件驱动编程时。

用了 WeakMap 后引用的对象,就会在失效时自动被垃圾回收。

如果你在数组中做同样的 *** 作,仍然会持有该对象的引用的,但是会导致内存泄露。

示例代码如下:<?phpdeclare(strict_types=1);classFooBar{publicWeakMap$cache;publicfunction__construct(){$this->cache=newWeakMap();}publicfunctiongetSomethingWithCaching(object$obj){return$this->cache[$obj]??=$this->computeSomethingExpensive($obj);}publicfunctioncomputeSomethingExpensive(object$obj){var_dump("Igotcalled");returnrand(1,100);}}$cacheObject=newstdClass;$obj=newFooBar;//"Igotcalled"只会打印一次$obj->getSomethingWithCaching($cacheObject);$obj->getSomethingWithCaching($cacheObject);var_dump(count($obj->cache));//删除该对象后WeakMap会释放相应内存unset($cacheObject);var_dump(count($obj->cache));exit;对应的运行结果:变量语法调整8的new 和 instanceof 关键字支持用于任意表达式了,示例代码如下<?phpdeclare(strict_types=1);classFoo{}classBar{}$names=['Foo','Bar'];$class=new($names[array_rand($names)]);var_dump($class);exit;运行结果:对象的类名字面量8 中支持使用 $object::class 获取对象的类名,返回结果和 get_class($object) 是一样的。

示例代码:<?phpdeclare(strict_types=1);classTest{}$test=newTest();var_dump($test::class);var_dump(get_class($test));exit;运行结果:参数列表中允许出现可选的尾部逗号和数组中的尾部逗号一样,8也支持在参数列表中定义一个尾部逗号了。

示例代码:<?phpdeclare(strict_types=1);functionmethod_with_many_arguments($a,$b,$c,$d,){var_dump("thisisvalidsyntax");}method_with_many_arguments(1,2,3,4,);exit;上述代码运行结果:Stringable 接口8 引入了新的 Stringable 接口,只要某个类实现了 __toString 方法,就会被当作自动实现了 Stringable 接口(这一点和 Go 接口实现有些像),而不需要显式与声明实现该接口,示例代码:<?phpdeclare(strict_types=1);classFoo{publicfunction__toString(){return'Iamaclass';}}$obj=newFoo;var_dump($objinstanceofStringable);exit;运行结果:throw 已经支持被用作表达式8支持 throw 语句可以用在只允许表达式出现的地方,比如箭头函数、合并运算符和三元运算符等:示例代码<?phpdeclare(strict_types=1);$callable=fn()=>thrownewException();$nullableValue=null;//$value是非空的$value=$nullableValue??thrownewInvalidArgumentException();exit;捕获异常而不存储到变量8可以编写 catch (Exception) 代码来捕获异常,但是不用将其存储到一个变量里:<?phpdeclare(strict_types=1);$nullableValue=null;try{$value=$nullableValue??thrownewInvalidArgumentException();}catch(InvalidArgumentException){var_dump("Somethingwentwrong");}exit;上述代码运行结果:PHP 8 的新增对注解的支持注解实际上包含了多个 RFC:https://wiki.php.net/rfc/attributes_v2https://wiki.php.net/rfc/attribute_amendmentshttps://wiki.php.net/rfc/shorter_attribute_syntaxhttps://wiki.php.net/rfc/shorter_attribute_syntax_change注解是 PHP 8 引入的最大新特性之一,一开始理解起来可能有点困难(如果你有 Java 基础的话理解起来会相对简单)。

注解允许你添加元数据到 PHP 函数、参数、类等,这些元数据随后就可以通过可编程方式获取到,在 PHP 7 或者更低版本中实现这样的功能需要解析代码注释块,而通过注解可以直接访问深度集成到 PHP 自身。

编写一段示例代码方便你理解,假设你想要允许开发者添加中间件到控制器类/方法,使用注解,你可以这么做,示例代码:<?phpdeclare(strict_types=1);//首先,我们需要定义注解,注解本身只是一个原生的PHP类,并且自身被打上了注解的注释#[Attribute]classApplyMiddleware{publicarray$middlware=[];publicfunction__construct(...$middleware){$this->middleware=$middleware;}}//下面的语法会添加上述注解到MyController类,并且传入auth作为参数#[ApplyMiddleware('auth')]classMyController{publicfunctionindex(){}}//然后我们就可以在类中使用反射获取所有的ApplyMiddleware注解并读取给定的中间件参数$reflectionClass=newReflectionClass(MyController::class);$attributes=$reflectionClass->getAttributes(ApplyMiddleware::class);foreach($attributesas$attribute){$middlewareAttribute=$attribute->newInstance();var_dump($middlewareAttribute->middleware);}exit;运行上述代码,打印结果:8新增构造函数属性提示支持这个新特性是一个语法简写,支持将属性声明和构造函数属性初始化合并在一起,示例代码如下:<?phpdeclare(strict_types=1);classUser{publicfunction__construct(publicint$id,publicstring$name,){}}$user=newUser(1,'Marcel');var_dump($user->id);var_dump($user->name);exit;上述代码运行结果:php8的Trait 支持定义抽象私有方法,示例代码如下:<?phpdeclare(strict_types=1);traitMyTrait{abstractprivatefunctionneededByTheTrait():string;publicfunctiondoSomething(){returnstrlen($this->neededByTheTrait());}}classTraitUser{useMyTrait;//支持该语法privatefunctionneededByTheTrait():string{}//不支持该语法(错误的返回类型)//privatefunctionneededByTheTrait():stdClass{}//支持该语法(非静态方法变成了静态方法)//privatestaticfunctionneededByTheTrait():string{}}exit;php8新增对 match 表达式支持match 表达式和 switch 分支语句类似,不过在语义上match表达式会更加安全并且可以直接返回值:示例代码如下<?phpdeclare(strict_types=1);echomatch(1){0=>'Foo',1=>'Bar',2=>'Baz',};exit;上述代码运行结果:PHP 8 引入了新的名为 mixed 的类型该类型等价于 array| bool| callable |int |float |null |object |resource |string,示例代码如下:<?phpdeclare(strict_types=1);functiondebug_function(mixed...$data){var_dump($data);}debug_function(1,'string',[]);exit;上述代码运行结果:8新增对 命名参数 的支持命名参数允许基于参数名称传递参数到函数,而不是参数所在的位置。

那么这样一来,函数参数就可以自解释了且与顺序无关,并且允许跳过默认值,示例代码如下:<?phpdeclare(strict_types=1);array_fill(start_index:0,num:100,value:50);exit;新增对空安全运算符 ?-> 的支持该运算符的左侧评估为 null 时,整个代码链路的执行就会被终止并且整体评估为 null。

但是如果要不为 null ,那就要和普通的 -> 运算符功能一样:<?phpdeclare(strict_types=1);classUser{publicfunctiongetAddress(){}}$user=newUser();$country=$user?->getAddress()?->country?->iso_code;var_dump($country);exit;上述代码运行结果:以上是本文的全部内容,希望对大家的学习有帮助,也希望大家多多支持 php自学中心

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/652023.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-17
下一篇 2022-04-17

发表评论

登录后才能评论

评论列表(0条)

保存