命名参数
- 1 可以指定参数传入,跳过可选参数 ;2 指定参数是无需遵循传入顺序。
- 看例子把 解释起来 比较 费劲
1public function response(array $data = [],int $code = 200,string $msg = "") : array
2{
3 return ['data'=> $data, 'code'=> $code,'msg' => $msg];
4}
5
6// php7
7$this->response([],200,"其他的提示信息");//非必须参数只能按顺序写
8
9// php8以后
10$this->response(msg: "其他的提示信息")//指定参数传入与响应
`Nullsafe` 运算符
1$user = null;
2
3// php7
4if($user){
5 $order = $user->lastOrder();
6 if($order){
7 $discountAmount = $order->getDiscountAmount();
8 }
9}
10//对于参数对象可能为 null 并且会执行方法的情况 ?? 就没法去处理了
11
12// php8 以后
13$discountAmount = $user?->lastOrder()?->getDiscountAmount();
枚举类型 & `match` 表达式
- 枚举类型 可以替换原来 常量定义码的作用,并且更加灵活,以下是一种使用的方式
match
替换 switch
可以减少 因为弱类型比较转换,带来的 bug
1enum ResponseCode: int
2{
3 case SUCCESS = 200;
4 case SYS_ERROR = 500;
5
6 public static function getMessageByCode(int $code): string
7 {
8 $responseCode = self::tryFrom($code);
9 if (!$responseCode) {
10 return '未定义错误码';
11 }
12 return self::getMessage($responseCode);
13 }
14
15 private static function getMessage(self $value): string
16 {
17 return match ($value) {
18 self::SUCCESS => "成功",
19 self::SYS_ERROR => "系统错误",
20 };
21 }
22}
23// 响应值构造使用
24public function success(array|object $data = [], string $msg = "", int|object $code = ResponseCode::SUCCESS): JsonResponse
25{
26 $res = new stdClass();
27 $res->data = $data ?: (object)[];
28 $res->code = is_object($code) ? $code->value : $code;
29 $res->msg = $msg ?: ResponseCode::getMessageByCode($res->code);
30 return response()->json($res);
31}
php8 的 opcache 与 jit(Just In Time)
php
的 opcache
对运行效率的提示是极其巨大,建议 php7
以上的版本 都开起来。php8
之后 加入了 jit
机制,- 在
opcache
的基础上,对运行时的 opcodes
进行分析,对热点 opcodes
直接转换成指令码,来减少 VM
的翻译执行工作,所以代码会越跑越快 - 但是这个提升,效果没有
opcache
开启时起飞的感觉,实测下来 大概有 5% - 10% 左右的不稳定提升 - 毕竟
php
的项目的性能瓶颈,更多的在网络跟 IO
- 原理简易缩略图如下
- 就不多加说明了,附一份相关配置
1[opcache]
2# 加载扩展
3zend_extension=opcache.so
4# 开启扩展
5opcache.enable=1
6# 开启 cli 模式使用 opcahce
7opcache.enable_cli=1
8# opcache 共享内存大小,以兆字节为单位。
9opcache.memory_consumption=256
10# 用来存储预留字符串的内存大小,以兆字节为单位
11opcache.interned_strings_buffer=8
12# opcache 哈希表中可存储的脚本文件数量上限。 真实的取值是在质数集合 { 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987 } 中找到的第一个大于等于设置值的质数。 设置值取值范围最小值是 200,最大值在 PHP 5.5.6 之前是 100000,PHP 5.5.6 之后是 1000000。
13# laravel 日常 32531 就够用 项目很大的情况下用 65407或者130987
14opcache.max_accelerated_files=100000
15# 浪费内存的上限,以百分比计。 如果达到此上限,那么 OPcache 将产生重新启动续发事件。
16opcache.max_wasted_percentage=5
17#如果启用,OPcache 将在哈希表的脚本键之后附加脚本的工作目录,以避免同名脚本冲突的问题。 禁用此选项可以提高性能,但是可能会导致应用崩溃。
18opcache.use_cwd=1
19# boolean 是否开启脚本文件变更验证
20opcache.validate_timestamps=0
21# 检查脚本时间戳是否有更新的周期,以秒为单位。 设置为 0 会导致针对每个请求, OPcache 都会检查脚本更新
22opcache.revalidate_freq=60
23# 不需要注解功能的 就关闭 需要注解才开启
24opcache.save_comments=0
25#开启jit的debug
26opcache.jit_debug=1
27# jit的模式 默认为 tracing
28opcache.jit=1255
29# jit缓存的尺寸; 默认值为 0, 也就是禁用 JIT
30opcache.jit_buffer_size=256M
- 以上的配置在实际应用中,需要通过实际
opcache
的运行情况进行监控与调整。怎么监控与调整,等以后有时间再聊。 opcode.jit
的配置有点复杂。- 它接受
disable,on,off,trace,function
,和按顺序排列的 4 个不同标志的 4 位值。 - disable:在启动时完全禁用JIT功能,并且在运行时无法启用。
- off:禁用,但是可以在运行时启用JIT。
- on:启用tracing模式。
- tracing:细化配置 的别名 1254。
- function:细化配置 的别名 1205。
jit
四位配置顺序是:CPU
特定的优化标志、寄存器分配、JIT
触发器、优化级别,官方给的推荐值为1255CPU
特定的优化标志:R
-寄存器分配:- 0 不执行寄存器分配
- 1 使用本地线性扫描寄存器分配器
- 2 使用全局线性扫描寄存器分配器
JIT
触发器:- 0 JIT在第一次脚本加载时的所有功能
- 1 首次执行时的JIT函数
- 2 在第一个请求时进行概要分析,并在第二个请求时编译热功能
- 3 动态分析并编译热功能
- 4 在文档注释中使用@jit标记编译函数
- 5 跟踪JIT
O
-优化级别:- 0 不要准时
- 1 最小JIT(调用标准VM处理程序)
- 2 选择性VM处理程序内联
- 3 基于单个函数的静态类型推断的优化JIT
- 4 静态类型推断和调用树的优化JIT
- 5 基于静态类型推断和内部过程分析的优化JIT
- 所以 1255 指的是, 启用AVX指令生成,使用本地线性扫描寄存器分配器,跟踪 JIT,基于静态类型推断和内部过程分析的优化 JIT
- function 是C = 1,R = 2,T = 0,O = 5的别名。1205
- tracing 是C = 1,R = 2,T = 5,O = 4的别名。1254
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/23099.html