简单的问题,简单的代码。这有效:
$x = &$_SESSION['foo'];
这不会:
$x = (isset($_SESSION['foo']))?&$_SESSION['foo']:false;
它抛出PHP Parse error: syntax error, unexpected '&'
。使用条件运算符时是否不能通过引用传递,为什么不呢?如果?
和之间有空格也会发生&
。
简单的问题,简单的代码。这有效:
$x = &$_SESSION['foo'];
这不会:
$x = (isset($_SESSION['foo']))?&$_SESSION['foo']:false;
它抛出PHP Parse error: syntax error, unexpected '&'
。使用条件运算符时是否不能通过引用传递,为什么不呢?如果?
和之间有空格也会发生&
。
在非常简单的情况下,这个表达式是非法的;
$c = condition ? &$a : &$b; // Syntax error
可以这样写:
$c = &${ condition ? 'a' : 'b' };
在您的特定情况下,由于如果条件为假,您不会通过引用进行分配,因此更好的选择似乎是:
$x = isset($_SESSION['foo']) ? $x = &$_SESSION['foo'] : false;
简单的回答:没有。如果/其他,你将不得不采取很长的路要走。一次有一个引用,而下一次有一个值,这也是很少见的,并且可能会令人困惑。我会发现这更直观,但是我当然不知道您的代码:
if(!isset($_SESSION['foo'])) $_SESSION['foo'] = false;
$x = &$_SESSION['foo'];
至于为什么:不知道,可能解析器必须在什么时候认为某些东西是价值的副本或引用的创建,以这种方式无法在解析时确定。
咱们试试吧:
$x =& true?$y:$x;
解析错误:语法错误,意外的“?”,期待 T_PAAMAYIM_NEKUDOTAYIM 在...
$x = true?&$y:&$x;
解析错误:语法错误,意外的 '&' 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 4乙:
(refcount=1, is_ref=0) ,null
不幸的是,你不能。
$x=false;
if (isset($_SESSION['foo']))
$x=&$_SESSION['foo'];
此错误报告的评论可能会对该问题有所了解:
http ://bugs.php.net/bug.php?id=53117 。
本质上,尝试从三元运算符的结果中分配引用的两个问题是:
$x = (expression)
不是引用分配,即使(expression)
是引用(它不是;参见第 1 点)。