使用三元运算符赋值?
我使用的是 Perl 5.8,需要分配一个默认值。我最终这样做了:
if ($model->test) {
$review = "1"
} else {
$review = ''
}
$model->test
的值将是 "1"
或未定义。如果 $model->test
中有内容,请将 $review
设置为 "1"
,否则将其设置为 ''< /代码>。
因为它不是 Perl 5.10,所以我无法使用新的时髦的定义或运算符。我的第一反应是像这样使用三元运算符......
defined($model->test) ? $review = "1" : $review = '';
但这也不起作用。
有谁知道如何更有效地分配它? 珍妮
I am on Perl 5.8 and am needing to assign a default value. I ended up doing this:
if ($model->test) {
$review = "1"
} else {
$review = ''
}
The value of $model->test
is going to be either "1"
or undefined. If there's something in $model->test
, set $review
to "1"
otherwise set it equal to ''
.
Because it's not Perl 5.10 I can't use the new swanky defined-or operator. My first reaction was to use the ternary operator like this...
defined($model->test) ? $review = "1" : $review = '';
but that didn't work either.
Does anyone have an idea how to assign this more efficiently?
Janie
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
我通常将其写为:
其中括号是为了让其他阅读代码的人清楚起见。
I'd usually write this as:
where the parentheses are for clarity for other people reading the code.
你有一个优先级问题。你所拥有的与 You can make it work with parens 相同
。
但将作业移出会干净得多。
继续下去,检查该值是否已定义根本没有意义。鉴于仅有的两个可能值是
undef
和字符串1
,一个简单的真值测试就可以了。事实上,既然你希望真实值不变,你可以简单地使用以下
最后,你真的需要将
undef
更改为空字符串吗?如果没有,您可以简单地使用以下命令:You have a precedence problem. What you have is the same as
You could make it work with parens.
But it's much cleaner to move the assignment out.
Moving along, there's no point in checking if the value is defined at all. Seeing as the only two possible values are
undef
and the string1
, a simple truth test would do.In fact, since you want true values unchanged, you could simply use the following
Finally, do you really need to change
undef
into to an empty string? If not, you can simply use the following:然后就用这个:
Then just use this:
除了条件运算符之外,我还经常喜欢使用
do
,它返回最后计算的表达式的值:Besides the conditional operator, I often like to use
do
, which returns the value from the last evaluated expression:我假设
$model->test
应该返回 true 或 false 值。除非明确指出 false 值为
undef
,否则可以重写该方法以开始返回一些其他 false 值。这会破坏仅检查值是否已定义的任何内容。
(我认为该方法返回
undef
而不是规范的 false 值是一个错误。)因此设置
$review
的最佳方法是测试返回的真实性价值;不是它的定义。我想指出的是,这仍然存在一个错误。
如果您希望能够将该值用作数字,则如果该值为假,它将发出警告。
要解决此问题,您应该返回
!1
(规范错误值),它将返回一个字符串''
值,但也具有数值 0。它可以简化为:
如果您只想在值为 false 时更改该值,则可以使用 or 运算符
||
。如果您真的只想知道它是否已定义,为什么不使用
已定义
。如果您只想在未定义时更改该值,并且您有 Perl 5.10 或更高版本,则可以使用 定义或运算符 (
//
)。在较旧的 Perl 上,这需要多个语句。
I assume that
$model->test
is supposed to return a true or false value.Unless it specifically states that the false value is
undef
, the method could be rewritten to start returning some other false value instead.Which would break anything that only checks if the value is defined.
( I think it is a bug that the method returns
undef
instead of the canonical false value. )So the best way to set
$review
is to test the truthfulness of the returned value; not it's definedness.I would like to point out that this still has a bug in it.
If you want to be able to use the value as a number, it will emit warnings if it was false.
To fix that you should return
!1
(canonical false value), which will return a value that is the string''
, but also has the numerical value of 0.Notice that it could be simplified to just:
If you only want to change the value only when it is false, you could use the or operator
||
.If you really only want to know if it is defined, or not why don't you just use
defined
.If you want to change the value only when it is undefined, and you have Perl 5.10 or newer you could use the defined-or operator (
//
).On an older Perl, that would require more than one statement.
首先,“这也不起作用”并不是您能告诉我们的最有帮助的事情。重要的是要确切地知道它为什么不起作用:它做了什么,您期望什么,以及它们有何不同?
但问题在于
运算符优先级。条件运算符
? :
比赋值运算符=
绑定得更紧密,因此上面等价于:因此,如果定义了
$model->test
,则执行等价操作 您可以用括号解决这个问题:
但实际上,您为什么要这样做?当您想要使用结果时,条件(三元)运算符非常有用。如果结果将被丢弃,就像这里一样,那么使用 if/else 语句会更清晰(而且,正如您所见,更不容易出错):
或者,如果您坚持将其写在一行上:
如果您确实想使用条件表达式,可以这样做:
这可能是一种合理的方法。
BUT:
define
运算符本身会产生"1"
(true) 或""
(false)。所以整个事情可以简化为:First of all, "That didn't work either" is not the most helpful thing you could tell us. It's important to know exactly how it didn't work: what did it do, what did you expect, and how to they differ?
But the problem with
is operator precedence. The conditional operator
? :
binds more tightly than the assignment operator=
, so the above is equivalent to:So if
$model->test
is defined, it does the equivalent ofYou can fix that problem with parentheses:
But really, why would you want to? The conditional (ternary) operator is useful when you want to use the result. If the result is going to be discarded, as it is here, it's clearer (and, as you've seen, less error-prone) to use an if/else statement:
or, if you insist on writing it on one line:
If you really want to use a conditional expression, you can do this:
which is probably a reasonable way to do it.
BUT :
The
defined
operator itself yields either"1"
(true) or""
(false). so the whole thing can be reduced to: