几个月前我升级到了PHP 8.0,和许多开发人员一样,我遇到了麻烦,这个通知变成了警告。我不知道处理这个问题的正确方法,所以我想知道如何在不膨胀代码的情况下解决这个问题。
以前我会这样做:
public function myFunction($options = []){
//we know $options is an array, so let's check if the key is there and get its value at the same time
if($run = $options['run']){
//do something with $run
}
}
$options被初始化为一个数组,如果定义了键"run",我会准备好使用它的值。有人建议我现在用这段简单的代码处理的是…
public function myFunction($options = false){
if(isset($options['run']){
$run = $options['run'];
//do something with $run
}
}
在我看来,这似乎增加了一个额外的不必要的步骤:这真的应该如何处理吗?
这样做可以避免典型的if/else块
$run = $options['run'] ?? null;
了解更多详细信息https://wiki.php.net/rfc/isset_ternary
您可以通过附加"在表达式之前$如果密钥不存在,run将为null:
if($run = @$options['run']){
//do something with $run
}
错误控制操作员(php.net(