简单的问题,简单的代码。这有效:
$x = &$_SESSION['foo'];
这不是:
$x = (isset($_SESSION['foo']))?&$_SESSION['foo']:false;
抛出PHP Parse error: syntax error, unexpected '&'
。使用条件运算符时是否无法通过引用传递,为什么不呢?如果?
和&
之间有空格,也会发生。
答案 0 :(得分:17)
在非常简单的情况下,这个表达式是非法的;
$c = condition ? &$a : &$b; // Syntax error
可以这样写:
$c = &${ condition ? 'a' : 'b' };
在您的具体情况下,如果条件为假,您没有通过引用进行分配,那么更好的选择似乎是:
$x = isset($_SESSION['foo']) ? $x = &$_SESSION['foo'] : false;
答案 1 :(得分:16)
简单回答:不。你必须要花很长时间来使用if / else。一次引用和下一个引用值也很少见并且可能令人困惑。我会发现这更直观,但我当然不知道你的代码:
if(!isset($_SESSION['foo'])) $_SESSION['foo'] = false;
$x = &$_SESSION['foo'];
至于为什么:不知道,可能它必须在什么时候解析器认为某些东西是值的副本或引用的创建,这样就无法在解析时确定。
答案 2 :(得分:2)
不幸的是,你不能。
$x=false;
if (isset($_SESSION['foo']))
$x=&$_SESSION['foo'];
答案 3 :(得分:2)
让我们试试:
$x =& true?$y:$x;
Parse error: syntax error, unexpected '?', expecting T_PAAMAYIM_NEKUDOTAYIM in...
$x = true?&$y:&$x;
Parse error: syntax error, unexpected '&' in...
所以,你看,它甚至都不解析。 Wikken可能是正确的,为什么不允许这样做。
你可以通过一个功能解决这个问题:
function &ternaryRef($cond, &$iftrue, &$iffalse=NULL) {
if ($cond)
return $iftrue;
else
return $iffalse;
}
$x = 4;
$a = &ternaryRef(true, $x);
xdebug_debug_zval('a');
$b = &ternaryRef(false, $x);
xdebug_debug_zval('b');
给出:
a:
(refcount=2, is_ref=1),int 4b:
(refcount=1, is_ref=0),null
答案 4 :(得分:0)
对这个错误报告的评论可能会对这个问题有所了解:
http://bugs.php.net/bug.php?id=53117
实质上,尝试从三元运算符的结果中分配引用的两个问题是:
$x = (expression)
不是引用分配,即使(expression)
是引用(它不是引用;请参阅第1点)。