Slevomat Coding Standard 8.19.0版本发布:PHP 8.4属性支持与多项优化
Slevomat Coding Standard是一个广受欢迎的PHP代码规范检查工具,它基于PHP_CodeSniffer构建,提供了大量现代化的代码规范检查规则。该项目由捷克开发者Jan Mikes维护,已经成为许多PHP项目代码质量保障的重要组成部分。
PHP 8.4属性支持增强
8.19.0版本最重要的改进是对即将到来的PHP 8.4版本中新特性的支持。PHP 8.4引入了多项关于类属性的重要改进:
-
非对称可见性支持:PHP 8.4允许属性在声明时使用不同的读写可见性,例如
private readonly或public readonly private writeonly这样的组合。新版本已经完全支持这种语法,不会产生误报。 -
final/abstract属性:现在属性也可以使用
final和abstract修饰符,这在某些设计模式中非常有用。代码规范检查器已能正确处理这些修饰符。 -
属性钩子兼容性:PHP 8.4引入了属性钩子(property hooks)的概念,这是一种新的元编程特性。新版本确保这些新语法不会破坏现有的代码规范检查规则。
重要问题修复
数组部分键名检查优化
SlevomatCodingStandard.Arrays.DisallowPartiallyKeyed规则修复了误报问题。该规则原本用于检测数组中部分元素有键名而部分没有的情况,这种不一致的写法可能导致维护困难。修复后,规则能更准确地识别真正的问题代码。
类成员间距规则改进
SlevomatCodingStandard.Classes.ClassMemberSpacing规则之前在某些情况下会意外删除代码或注释,这在8.19.0版本中得到了修复。现在它能更安全地处理类成员之间的间距问题,不会影响代码的实际内容。
认知复杂度计算修正
认知复杂度(Cognitive Complexity)是衡量代码理解难度的指标。SlevomatCodingStandard.Complexity.Cognitive规则之前对do...while循环的处理有误,会将T_DO和T_WHILE都计入复杂度。实际上,一个do...while结构应该只增加一次复杂度计数,新版本已修正这一问题。
类常量类型提示灵活性增强
SlevomatCodingStandard.TypeHints.ClassConstantTypeHint规则新增了fixableNativeTypeHint选项。这个改进特别实用,现在开发者可以选择只对私有(private)常量自动添加类型提示,而保持公开(public)或受保护(protected)常体的类型提示手动维护,这在某些需要保持API稳定的场景下非常有用。
构造器属性提升修复
SlevomatCodingStandard.Classes.RequireConstructorPropertyPromotion规则修复了当参数名带有属性(attribute)时的自动修复问题。PHP 8.0引入的属性(attributes)语法现在能与此规则完美配合,确保自动修复过程不会破坏带有属性的构造函数参数。
总结
Slevomat Coding Standard 8.19.0版本在保持对最新PHP版本特性的支持同时,修复了多个实际使用中的痛点问题。特别是对PHP 8.4的前瞻性支持,体现了该项目紧跟PHP语言发展的承诺。各项修复也使得代码规范检查更加精确可靠,减少了误报和自动修复可能带来的副作用。对于追求代码质量的PHP团队来说,升级到这个版本将获得更好的开发体验。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0188
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0113
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java03
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08