电话
400 9058 355
Java中关系运算符共6个:<、>、<=、>=、==、!=,均返回boolean值,优先级介于算术与逻辑运算符之间;它们仅作原始语义比较(值或引用),不自动类型转换、不深比较、不处理null安全。
Java 中的关系运算符只有 6 个,不是 8 个也不是 4 个:、=、==、!=。它们全部返回 boolean 类型值,且优先级低于算术运算符、高于逻辑运算符(如 &&),这点在复合条件中极易出错。
每个运算符都严格比较两个操作数的「值」(对基本类型)或「引用」(对对象),不自动类型转换也不做内容深比较:
== 比较的是内存地址(对象)或数值相等(基本类型),String a = "abc"; String b = "abc"; a == b 可能为 true(因字符串常量池),但 new String("abc") == new String("abc") 一定为 false
equals() 不是关系运算符,它是方法,必须显式调用;误写成 a.equals = b 或漏掉括号会直接编译失败 和 >= 是单个运算符,不能写成 (空格分隔)或 =(顺序颠倒),否则报错 illegal start of expression关系表达式常作为控制结构的判断依据,但要注意隐式类型限制和短路逻辑干扰:
int 和 double 可比,但 String 和 Integer 直接用 == 或 会编译报错 bad operand types for binary operator
if (a != null && a.length() > 0) 中,&& 的短路特性依赖左侧关系表达式先求值;若写成 &(按位与),则右侧即使抛 NullPointerException 也会执行==:建议用 Math.abs(a - b) 替代 a == b,避免精度误差导致逻辑跳变
== 是最容易引发 Bug 的关系运算符,尤其在对象比较场景:
Integer 在 [-128, 127] 范围内用 == 可能“碰巧”成功(因缓存),超出范围就失效:Integer i1 = 128
; Integer i2 = 128; System.out.println(i1 == i2); // false
Object.equals(),其行为等价于 ==(即比地址),除非重写 equals() 方法== 模拟多分支;Java 14+ 支持 switch 表达式,但 case 标签仍要求常量或枚举,不能写 case x > 5:
真正麻烦的从来不是记不住这 6 个符号,而是忘记它们只做原始语义比较——不处理 null 安全、不兼容泛型擦除、不感知业务意义上的“相等”。写条件前先问一句:我在比值、比引用,还是本该调用某个 equals() 或 compareTo()?
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...