PHP 8.0.0 Released!

2024-05-13 00:38
文章标签 php 8.0 released

本文主要是介绍PHP 8.0.0 Released!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

2020年11月26日,PHP开发团队宣布将发布PHP 8.0.0。此版本标志着PHP语言最新的主要版本。

PHP 8.0具有许多改进和新功能,例如:

    • 1、Union Types ,联合类型
    • 2、Named Arguments,命名参数
    • 3、Match Expressions,匹配表达式
    • 4、Attributes,注解
    • 5、Constructor Property Promotion,构造函数属性提升
    • 6、Nullsafe Operator,Nullsafe 运算符
    • 7、WeakMap,弱映射
    • 8、JIT,Just-In-Time ,即时编译
    • 9、字符串与数字的比较
    • 10、其他:
      • (1)、对算术/按位运算符进行更严格的类型检查;
      • (2)、static 返回类型
      • (3)、混合类型
      • (4)、一些新增函数

1、Union Types ,联合类型

PHP 7

class Number {/** @var int|float */private $number;/*** @param float|int $number*/public function __construct($number) {$this->number = $number;}
}new Number('NaN'); // Ok

PHP 8

class Number {public function __construct(private int|float $number) {}
}new Number('NaN'); // TypeError

2、Named Arguments,命名参数

仅指定必需的参数,跳过可选的参数。
参数是与顺序无关的且具有自记录功能。

PHP 7

htmlspecialchars($string, ENT_COMPAT | ENT_HTML401, 'UTF-8', false);

PHP 8

htmlspecialchars($string, double_encode: false);

3、Match Expressions,匹配表达式

新的匹配类似于switch,并具有以下功能:

Match是一个表达式,表示其结果可以存储在变量中或返回。
Match分支仅支持单行表达式,不需要中断。声明。
匹配进行严格的比较

PHP 7

switch (8.0) {case '8.0':$result = "Oh no!";break;case 8.0:$result = "This is what I expected";break;
}
echo $result;
//> Oh no!

PHP 8

echo match (8.0) {'8.0' => "Oh no!",8.0  => "This is what I expected",
};
//> This is what I expected

4、Attributes,注解

PHP 7

class PostsController
{/*** @Route("/api/posts/{id}", methods={"GET"})*/public function get($id) { /* ... */ }
}

PHP 8

class PostsController
{#[Route("/api/posts/{id}", methods: ["GET"])]public function get($id) { /* ... */ }
}

5、Constructor Property Promotion,构造函数属性提升

PHP 7

class Point {public float $x;public float $y;public float $z;public function __construct(float $x = 0.0,float $y = 0.0,float $z = 0.0,) {$this->x = $x;$this->y = $y;$this->z = $z;}
}

PHP 8

class Point {public function __construct(public float $x = 0.0,public float $y = 0.0,public float $z = 0.0,) {}
}

6、Nullsafe Operator,Nullsafe 运算符

现在,您可以使用带有新的nullsafe运算符的调用链来代替空检查条件。当对链中一个元素的求值失败时,整个链的执行将中止,并且整个链的求值为空。
PHP 7

$country =  null;if ($session !== null) {$user = $session->user;if ($user !== null) {$address = $user->getAddress();if ($address !== null) {$country = $address->country;}}
}

PHP 8

$country = $session?->user?->getAddress()?->country;

7、WeakMap,弱映射

WeakMaps 允许创建从对象到任意值的映射(类似 SplObjectStorage),而不会阻止对用作 key 的对象进行垃圾回收。如果对象key是垃圾回收的,则将其简单地从WeakMap中删除。

PHP 7.4 中,已经引入了对 WeakReference(弱引用)的支持。但是,原始的弱引用本身用途有限,而 WeakMaps 在实践中更为常用。由于没有提供注册销毁回调的功能,因此无法在 PHP 弱引用之上实现有效的弱映射。

弱映射的一般用例是将数据与单个对象实例相关联,而不会强迫它们保持活动状态,避免长时间运行的进程无谓地占用内存。

class FooBar {private WeakMap $cache;public function getSomethingWithCaching(object $obj) {return $this->cache[$obj] ??= $this->computeSomethingExpensive($obj);}// ...
}

8、JIT,Just-In-Time ,即时编译

PHP 8引入了两个JIT编译引擎。Tracing JIT是两者中最有希望的,它在综合基准测试中的性能提高了大约3倍,在某些特定的长期运行的应用程序中提高了1.5–2倍。典型的应用程序性能与PHP 7.4相当。

JIT对PHP 8性能的贡献

9、字符串与数字的比较

PHP 8使用数字与字符串进行比较时,它将数字转换为字符串并使用字符串比较。

PHP 7

0 == 'foobar' // true

PHP 8

0 == 'foobar' // false

10、其他:

(1)、对算术/按位运算符进行更严格的类型检查;

var_dump([] % [42]);
// int(0)
// WTF?

(2)、static 返回类型

在PHP中,static的特殊类名称指的是实际调用方法的类,即使该方法是继承的。这称为“后期静态绑定”(LSB)。使它static可用作返回类型(除了self和parent类型之外)。

class Test {public function createFromWhatever($whatever): static {return new static($whatever);}
}

在这里,我们要指定XXX::createFromWhatever()将始终创建的实例XXX,而不是某些父类的实例。

另一个是withXXX()用于更改不可变对象的样式接口:

class Test {public function withWhatever($whatever): static {$clone = clone $this;$clone->whatever = $whatever;return $clone;}
}

(3)、混合类型

// Valid exampleclass A
{public function foo(int $value) {}
}class B extends A
{// Parameter type was widened from int to mixed, this is allowedpublic function foo(mixed $value) {}
}

(4)、一些新增函数

str_starts_with
str_ends_with
str_contains

str_starts_with ( string $haystack , string $needle ) : bool
str_ends_with ( string $haystack , string $needle ) : bool
str_contains ( string $haystack , string $needle ) : boolstr_starts_with 检查一个字符串是否以另一个字符串开头并是否返回布尔值(true/ false)。
str_ends_with 检查一个字符串是否以另一个字符串结尾,是否返回布尔值(true/ false)。str_contains检查另一个字符串中是否包含一个字符串,并返回一个布尔值(true/ false)是否找到该字符串。


END


如有问题请在下方留言。

或关注我的公众号“孙三苗”,输入“联系方式”。获得进一步帮助。

在这里插入图片描述

这篇关于PHP 8.0.0 Released!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984200

相关文章

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

mysql重置root密码的完整步骤(适用于5.7和8.0)

《mysql重置root密码的完整步骤(适用于5.7和8.0)》:本文主要介绍mysql重置root密码的完整步骤,文中描述了如何停止MySQL服务、以管理员身份打开命令行、替换配置文件路径、修改... 目录第一步:先停止mysql服务,一定要停止!方式一:通过命令行关闭mysql服务方式二:通过服务项关闭

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

php中json_decode()和json_encode()

1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool $assoc ] ) 接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 参数 json

如何将文件夹里的PHP代码放到一个文件里

find ./dir -name "*.php" -exec 'cat' {} \; > dir.out

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA

PHP防止SQL注入的方法(1)

(1)mysql_real_escape_string – 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 使用方法如下: $sql = "select count(*) as ctr from users where username ='".mysql_real_escape_string($username)."' and password='". mysql_r