Using assignment as a condition expression?
Consider:
if开发者_高级运维 (a=5) {
/* do something */
}
How does the assignment work as a condition?
Is it based on non-zero value of l-value?
C++ — ISO/IEC 14882:2003(E)
[5.17/1]
There are several assignment operators, all of which group right-to-left. All require a modifiable lvalue as their left operand, and the type of an assignment expression is that of its left operand. The result of the assignment operation is the value stored in the left operand after the assignment has taken place; the result is an lvalue.
The result of the expression a = 5
is 5
.
[6.4/4]
[..] The value of a condition that is an expression is the value of the expression, implicitly converted tobool
for statements other thanswitch
. [..]
A conversion to bool
takes place.
[4.12/1]
An rvalue of arithmetic, enumeration, pointer, or pointer to member type can be converted to an rvalue of typebool
. A zero value, null pointer value, or null member pointer value is converted tofalse
; any other value is converted totrue
.
5
converts to boolean true
.
[6.4.1/1]
If the condition (6.4) yields true the first substatement is executed. [..]
true
is treated as an if
statement success.
C — ISO/IEC 9899:1999(E)
[6.5.16/3]
An assignment operator stores a value in the object designated by the left operand. An assignment expression has the value of the left operand after the assignment, but is not an lvalue. [..]
The result of the expression a = 5
is 5
.
[6.8.4.1/2]
In both forms, the first substatement is executed if the expression compares unequal to 0. [..]
5
is treated as an if
statement success.
General
Code like this is almost always a mistake; the author likely intended if (a == 5) {}
. However, sometimes it is deliberate. You may see code like this:
if (x = foo()) {
cout << "I set x to the result of foo(), which is truthy";
// ... stuff
}
Every non-zero value will be considered as true.
So some people will suggest you write
5 == a
to avoid that you make mistake == by =.
if(a=x)
is equivalent to if(x)
in addition to a
assigned with x
. So if the expression x
evaluates to a non-zero value, then if(x)
simply becomes if(true)
. Otherwise, it becomes if(false)
.
In your case, since x = 5
, that means f(a=5)
is equivalent to if(true)
in addition to a
assigned with 5
.
Yes, it is based on the zero/non-zero value which a is assigned. To some people (myself included) it is also considered bad practice to have expressions with side-effects in your code, so the mentioned code fragment would preferably be written as something like
a = 5;
...
if (a != 0) {
...
}
In more modern usage, you may sometimes see this pattern used to handle optional
s:
std::optional x = ...;
if (auto v = x) {
// Block only executes if x contained a value, accessible as *v
}
精彩评论