你可以将写范围限制调整为只限制构造函数,或者模拟私有和保护范围。要做到这一点,请将常量CONSTRUCTOR_WRITE_SCOPE、PRIVATE_WRITE_SCOPE、PROTECTED_WRITE_SCOPE中的一个传递给#[Immutable]属性构造函数。
#[Immutable]属性即使在PHP 7.4及更低版本中也可以使用!
#[Pure]
您可以将不会产生任何副作用的函数标记为pure函数。如果之后执行的结果未在代码中使用,则可以安全地删除此类函数。
PhpStorm将检测pure函数的冗余调用。
如果该函数被标记为pure函数,但您尝试在函数外部进行更改,即产生副作用,则PhpStorm将警告您并突出显示不安全的代码。
#[ExpectedValues]
使用此属性,您可以指定函数接受哪些值作为参数,以及可以返回哪些值。
这与expectedArguments()函数可以执行的操作类似.phpstorm.meta.php,不同之处在于meta版本更像是完成对手。相反,该属性假定参数或返回值没有其他可能的值。
例如,让我们看一下count函数:
count ( array|Countable $array_or_countable [, int $mode = COUNT_NORMAL ] ) : int
它接受的第二个参数是整数,但实际上,它不是整数。而是它是常数COUNT_NORMALor之一COUNT_RECURSIVE,对应于0和1。
您可以将#[ExpectedValues]属性添加到第二个参数。这就是这种情况下代码完成的方式。
没有元
在.phpstorm.meta.php中具有ExpectedArguments()
使用#[ExpectedValues]属性
如何指定可能的值或位掩码。
#[ExpectedValues]示例
让我们看一下response()Laravel中的助手。它以HTTP状态代码作为第二个参数。
这使我们缺少两个关键功能:
可能状态代码的代码完成
在编辑器中验证
我们可以通过添加属性 #[ExpectedValues(valuesFromClass: Response::class)]来解决此问题
#[NoReturn]
代码库中的某些功能可能会导致脚本执行停止。首先,从函数名称中并不总是很明显,例如,trigger_error()根据第二个参数可以停止执行。其次,PhpStorm不能总是检测到此类功能,因为深入分析可能会导致性能问题。
这就是为什么将这些功能标记为出口点,以通过添加#[NoReturn]属性来进行更准确的控制流分析的原因。
而且,PhpStorm将提供通过快速修复在整个层次结构中向下传播属性的功能,以进行更加明确的分析。
PhpStorm点击此处下载
到此这篇关于PhpStorm 2020.3:新增开箱即用的PHP 8属性的文章就介绍到这了,更多相关PhpStorm 2020.3新增PHP 8属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章: