以下代码在 C/C++ 中做了什么?
if (blah(), 5) {
//do something
}
应用逗号运算符,值 5 用于确定条件的真/假。
它将执行 blah() 并取回一些东西(大概),然后使用逗号运算符,并且 5 将是唯一用于确定表达式的真/假值的东西。
请注意,对于 blah() 函数的返回类型(未指定),可能会重载 , 运算符,从而使结果不明显。
如果逗号操作符没有被重载,代码类似这样:
blah();
if (5) {
// do something
}
如果逗号运算符重载,则结果将基于该函数。
#include <iostream>
#include <string>
using namespace std;
string blah()
{
return "blah";
}
bool operator,(const string& key, const int& val) {
return false;
}
int main (int argc, char * const argv[]) {
if (blah(), 5) {
cout << "if block";
} else {
cout << "else block";
}
return 0;
}
(编辑以显示逗号运算符重载场景。感谢 David Pierre 对此发表评论)
我知道这种代码应该做的一件事:它应该让编码器被解雇。在这样写的人旁边工作,我会有点害怕。
在病态的情况下,这取决于逗号运算符的作用......
class PlaceHolder
{
};
PlaceHolder Blah() { return PlaceHolder(); }
bool operator,(PlaceHolder, int) { return false; }
if (Blah(), 5)
{
cout << "This will never run.";
}
我会说这取决于 blah()。
关于更广泛的答案。逗号运算符(非重载)解析为,执行第一部分并返回第二部分。
因此,如果您有 (foo(),bar()) 两个函数都将被执行,但表达式的值计算为 bar() (以及表达式的类型)。
虽然我不会说这有合理的用法,但通常被认为有点难以阅读代码。主要是因为没有多少语言共享这样的结构。因此,根据个人经验,我会避免使用它,除非我将代码添加到预先存在的表达式中并且不想完全改变它的格式。
示例:我有一个宏(不讨论是否应该使用宏,有时甚至不是你写的)
FIND_SOMETHING(X) (x>2) ? find_fruits(x) : find_houses(x)
我通常在 my_possession = FIND_SOMETHING(34); 这样的作业中使用它
现在我想将日志添加到它以进行调试,但我无法更改查找功能。我可以做 :
FIND_SOMETHING(X) (x>2)?(LOG("找水果"),find_fruits(x)):(LOG("找房子"),find_houses(x))
以下是假设它是 C 代码,在 C 文件或 C++ 文件的 C 块中编写的:
如果是毫无意义的。它将调用 blah(),但是if根本不考虑 blah() 的结果。唯一考虑的是 5,因此 if 将始终评估为 true。IOW,您可以将此代码编写为
blah();
// do something
没有任何如果。
我有时会使用这样的结构来进行调试。无论blah的返回值如何,当我强制if close为真时。很明显,它不应该出现在生产代码中。