用==比字符串需分类型:std::string比内容,c风格字符串和char[]比地址;strcmp返回0才相等;数值比较防隐式转换;浮点数用abs(a-b)

用 == 比字符串?得看类型
直接用 == 判断相等,结果对不对,完全取决于你手里是什么类型。C++ 里“字符串”有好几种,每种行为不同:
-
std::string:支持==,比较的是内容,安全可靠 - C 风格字符串(
const char*):==比的是指针地址,不是内容,99% 是错的 -
char[]数组名:退化为指针,同样踩进地址比较坑
常见错误现象:const char* a = "hello"; const char* b = "hello"; if (a == b) {...} —— 这个条件可能真、可能假,取决于编译器是否做了字符串字面量合并,完全不可靠。
strcmp 只能用于 C 字符串,且返回值不是布尔
strcmp 是 C 标准库函数,头文件是 <cstring></cstring>,它不返回 true/false,而是返回整数:
- 返回
0表示相等 - 返回负数表示左小右大
- 返回正数表示左大右小
所以写 if (strcmp(a, b)) 是反逻辑的——它在「不相等」时才为真。正确写法必须显式判断:if (strcmp(a, b) == 0)。另外,strcmp 要求两个参数都非空,传入 nullptr 会崩溃。
立即学习“C++免费学习笔记(深入)”;
数值比较别被隐式转换带偏
数值类型之间用 == 看似简单,但混合类型时容易出事:
-
int x = 5; double y = 5.0; if (x == y):看似合理,但涉及int→double隐式转换,浮点精度问题可能让本该相等的值判为不等(尤其当y来自计算结果) -
size_t i = 1; int j = -1; if (i == j):j会被提升为无符号数,变成极大值,永远不等于i - 比较浮点数直接用
==几乎总是错的,该用std::abs(a - b)
自定义类型要自己重载 operator==
如果你写了类 struct Point { int x, y; };,直接写 p1 == p2 会编译失败——C++ 不知道怎么比。必须手动定义:
bool operator==(const Point& a, const Point& b) {
return a.x == b.x && a.y == b.y;
}注意两点:
- 函数得是
const引用参数,否则临时对象或const对象调用不了 - 如果类里有指针成员或资源句柄,光比地址没意义,得按语义深比较;如果比较代价高(比如含大数组),要考虑是否真需要频繁相等判断
最容易被忽略的一点:重载了 ==,往往也该顺手重载 !=,或者用 C++20 的 自动生成所有比较操作符——但老项目里还是得一个个补。










