简单的问题,简单的代码。这是可行的:
$x = &$_SESSION['foo'];
这不会:
$x = (isset($_SESSION['foo']))?&$_SESSION['foo']:false;
它抛出PHP Parse error: syntax error, unexpected '&'
。在使用条件运算符时不能通过引用传递吗?为什么不呢?如果?
和&
之间有空格,也会发生这种情况。
发布于 2010-08-03 00:57:20
答案很简单:不是。你必须使用if/else走很长一段路。一次有一个引用,下一次又有一个值,这也是很少见的,也可能会让人感到困惑。我会觉得这更直观,但我当然不知道你的代码:
if(!isset($_SESSION['foo'])) $_SESSION['foo'] = false;
$x = &$_SESSION['foo'];
至于原因:不知道,可能它必须在什么时候解析器认为某个东西是值的副本或引用的创建,在这种方式下无法在解析时确定。
发布于 2011-02-02 17:04:08
在非常简单的情况下,这个表达式是非法的;
$c = condition ? &$a : &$b; // Syntax error
可以这样写:
$c = &${ condition ? 'a' : 'b' };
在您的特定情况下,如果条件为false,则不是通过引用赋值,因此更好的选择似乎是:
$x = isset($_SESSION['foo']) ? $x = &$_SESSION['foo'] : false;
发布于 2010-08-03 00:59:03
不幸的是,你不能。
$x=false;
if (isset($_SESSION['foo']))
$x=&$_SESSION['foo'];
https://stackoverflow.com/questions/3389928
复制相似问题