在给定的代码中,我发现了以下序列,
data = POC_P_Status, TE_OK;
我不明白那是什么意思。
数据元素是否接收第一个或第二个元素或其他内容?
更新:
我在某个地方读到这种行为是这样的,
如果我写:
如果(数据=POC__Status,TE_OK){…}
那么如果TE_ OK为真,则teh-if子句将为真。
你是什么意思?
它将POC_P_Status
存储到data
中。
i = a, b; // stores a into i.
这相当于
(i = a), b;
因为逗号运算符的优先级低于赋值。
它相当于以下代码:
data = POC_P_Status;
TE_OK;
换句话说,它将POC_P_Status
分配给data
,并计算为TE_OK
。在第一种情况下,表达式是独立的,因此TE_OK
只有在它是一个有副作用的宏时才有意义。在第二种情况下,表达式实际上是if
语句的一部分,因此它的计算结果始终为TE_OK
的值。该语句可以重写为:
data = POC_P_Status;
if (TE_OK) { ... }
来自C11草案(http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf):
逗号运算符的左操作数计算为空表示在其评估之后有一个序列点。然后计算右操作数;结果有其类型和值。如果试图修改逗号运算符的结果或在下一个序列点之后访问它,行为是不确定的。
这意味着在表达式中:
a, b
对a
进行评估并丢弃,然后对b
进行评估。整个表达式的值等于b
:
(a, b) == b
逗号运算符通常用于需要多个赋值但只允许一个表达式的地方,例如for
循环:
for (int i=0, z=length; i < z; i++, z--) {
// do things
}
其他上下文中的逗号,如函数调用和声明,是而不是逗号运算符:
int func(int a, int b) {...}
^
|
Not a comma operator
int a, b;
^
|
Not a comma operator