百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

吊打面试官(四)--Java语法基础运算符一文全掌握

myzbx 2025-07-14 20:16 36 浏览

简介

本文介绍了Java运算符相关知识,包含运算规则,运算符使用经验,特殊运算符注意事项等,全文5400字。熟悉了这些内容,在运算符这块就可以吊打面试官了。

Java运算符的规则与特性


1. 贪心规则(Maximal Munch Rule)


贪心规则是指编译器在解析表达式时,会尽可能多地匹配字符,以形成最长的有效运算符或符号。编译器不会跳过空格合并,因此可以使用空格进行识别。


- **代码示例**:

```java

int a = 10; int b = a+++a; // 解析为 (a++) + a

```代码解释如下:

- 编译器会尽可能多地匹配运算符,因此 `a+++a` 被解析为 `(a++) + a`,而不是 `a + (++a)`。

- 最终结果是 `10 + 11 = 21`。

如何避免语句有歧义?:

1. **使用括号**:明确表达式的优先级,使用()表示优先。

```java int c = (a++) + b; ```


2. **添加空格**:编译器不会跳过空格合并,可以明确分隔运算符。

```java int c = a + ++b; ```


3. **拆分表达式**:将复杂的表达式拆分为多个简单的表达式,避免歧义。

```java int temp = a++; int c = temp + b; ```


2. 运算符优先级(Precedence)


运算符优先级决定了表达式中运算符的执行顺序。优先级高的运算符会先被计算。

- **常见运算符优先级(从高到低)**:

1. `()`(括号)

2. `++`、`--`(后缀递增/递减)、`+`、`-`(一元正负)、`!`、`~`(按位取反)

3. `*`、`/`、`%`(乘法、除法、取模)

4. `+`、`-`(加法、减法)

5. `<<`、`>>`、`>>>`(位移)

6. `<`、`<=`、`>`、`>=`、`instanceof`(比较)

7. `==`、`!=`(相等性比较)

8. `&`(按位与)

9. `^`(按位异或)

10. `|`(按位或)

11. `&&`(逻辑与)

12. `||`(逻辑或)

13. `?:`(三元运算符)

14. `=`、`+=`、`-=`、`*=`、`/=`、`%=`(赋值运算符)

- **示例**:

```java int result = 5 + 3 * 2;

// 3 * 2 先计算,结果是 5 + 6 = 11 ```


3. 运算符结合性(Associativity)


当表达式中出现多个相同优先级的运算符时,结合性决定了它们的计算顺序。结合性可以是左结合(从左到右)或右结合(从右到左)。

左结合运算符:

- 大多数运算符是左结合的,例如 `+`、`-`、`*`、`/`、`%`、`<<`、`>>`、`>>>`、`&`、`^`、`|`、`&&`、`||`。

- **示例**:

```java

int result = 10 - 5 - 2; // 从左到右计算,(10 - 5) - 2 = 3 ```

右结合运算符: - 赋值运算符(`=`、`+=`、`-=` 等)和三元运算符(`?:`)是右结合的。


- **示例**:

```java

int a, b, c; a = b = c = 5; // 从右到左计算,c = 5, b = c, a = b

```

4. 类型转换规则(Type Conversion Rules)

在表达式中,操作数的类型可能会自动转换,以满足运算符的要求。类型转换规则包括隐式转换(自动类型提升)和显式转换(强制类型转换)。


4.1 隐式类型转换(自动类型提升)当操作数的类型不同时,Java会自动将较小的类型提升为较大的类型。

- **规则**: - `byte` -> `short` -> `int` -> `long` -> `float` -> `double` - `char` -> `int`


- **示例**: ```java


int a = 5; double b = 2.5; double result = a + b; // a 被提升为 double,结果是 7.5

```


4.2 显式类型转换(强制类型转换)当需要将较大的类型转换为较小的类型时,必须使用显式类型转换。- **示例**: ```java double a = 5.7; int b = (int) a; // b 的值为 5,小数部分被截断 ```---


5. 短路规则(Short-Circuit Evaluation)

对于逻辑与(`&&`)和逻辑或(`||`)运算符,Java采用短路规则:如果第一个操作数已经能够确定整个表达式的结果,则不会计算第二个操作数。

- **示例**:

```java

int a = 5;

if (a > 0 || a / 0 == 1) {

// 不会抛出异常,因为 a > 0 为 true,短路规则生效

System.out.println("Short-circuit!"); }

```---


6. 赋值运算符的类型转换


复合赋值运算符(如 `+=`、`-=`、`*=` 等)会自动进行类型转换,即使可能导致数据丢失。

- **示例**:

```java

byte b = 10; b += 1000;

// 等价于 b = (byte)(b + 1000); System.out.println(b); // -46(数据丢失) ```


7. 字符串连接规则


`+` 运算符在用于字符串时会被重载,用于字符串连接。如果其中一个操作数是字符串,另一个操作数会被自动转换为字符串。

- **示例**:

```java

String result = "The answer is " + 42;

// "The answer is 42" ```---


8. 三元运算符的类型推断


三元运算符(`?:`)的结果类型是根据两个操作数的类型推断的。如果两个操作数的类型不同,结果类型将是它们的最小公共超类。

- **示例**:

```java

Number result = true ? 1 : 2.0;

// 结果是 Double 类型 System.out.println(result.getClass());

// class java.lang.Double ```


9. 位运算符的特殊规则


位运算符(如 `&`、`|`、`^`、`~`、`<<`、`>>`、`>>>`)直接操作二进制位,适用于整数类型。位运算符直接进行二进制操作,效率极高,常被用于进行特殊计算中。

9.1 按位与(`&`)

- **功能**:对两个操作数的每一位进行与操作,结果为1当且仅当两个位都为1。

- **示例**:

```java

int a = 5; // 二进制:0101

int b = 3; // 二进制:0011

int result = a & b; // 结果:0001 (1)

- **应用场景**:  - 判断特定位是否为1。  - 掩码操作,提取特定位。


9.2 按位或(`|`)

- **功能**:对两个操作数的每一位进行或操作,结果为1当且仅当至少一个位为1。

- **示例**:

```java

int a = 5; // 二进制:0101

int b = 3; // 二进制:0011

int result = a | b; // 结果:0111 (7) ```

- **应用场景**: - 设置特定位为1。 - 组合多个标志位。


9.3 按位异或(`^`)

- **功能**:对两个操作数的每一位进行异或操作,结果为1当且仅当两个位不同。

- **示例**:

```java

int a = 5; // 二进制:0101

int b = 3; // 二进制:0011

int result = a ^ b; // 结果:0110 (6)

```

- **应用场景**: - 交换两个变量的值。 - 切换特定位的状态。


9.4 按位取反(`~`)


- **功能**:对操作数的每一位进行取反操作,1变0,0变1。

- **示例**:

```java

int a = 5; // 二进制:0000 0101

int result = ~a; // 结果:1111 1010 (-6)

```

- **应用场景**: - 反转所有位。 - 计算补码。


9.5 左移(`<<`)

- **功能**:将操作数的二进制表示向左移动指定的位数,右侧空出的位用0填充。

- **示例**:

```java

int a = 5; // 二进制:0101

int result = a << 1; // 结果:1010 (10)

- **应用场景**:  - 快速乘以2的幂。  - 高效处理位掩码。9.6 算术右移(`>>`)- **功能**:将操作数的二进制表示向右移动指定的位数,左侧空出的位用符号位填充。- **示例**:  ```java  int a = -8; // 二进制:11111111111111111111111111111000  int result = a >> 1; // 结果:11111111111111111111111111111100 (-4)  ```- **应用场景**:  - 快速除以2的幂。  - 保留符号位。9.7 逻辑右移(`>>>`)- **功能**:将操作数的二进制表示向右移动指定的位数,左侧空出的位用0填充。- **示例**:  ```java  int a = -8; // 二进制:11111111111111111111111111111000  int result = a >>> 1; // 结果:01111111111111111111111111111100 (2147483644)  ```- **应用场景**:  - 无符号右移,忽略符号位。  - 处理无符号整数。---9.8 位运算符的常见应用场景


快速乘除法

- **左移(`<<`)**:用于快速乘以2的幂。 ```java

int a = 5; int b = a << 1; // 10,相当于 a * 2 ```


- **右移(`>>`)**:用于快速除以2的幂。 ```java

int a = 10; int b = a >> 1; // 5,相当于 a / 2 ```


位掩码操作位运算符常用于位掩码操作,用于选择性地操作特定位。

- **设置位**:

```java

int flags = 0;

flags |= 1 << 2; // 设置第2位

```

- **清除位**:

```java

flags &= ~(1 << 2); // 清除第2位

```


- **切换位**:

```java

flags ^= 1 << 2; // 切换第2位 ```


快速判断奇偶

使用按位与运算符 `&` 可以快速判断一个数是否为偶数。

int a = 5;boolean isEven = (a & 1) == 0; // false,5是奇数```交换两个变量的值使用按位异或运算符 `^` 可以在不使用临时变量的情况下交换两个变量的值。```javaint a = 5, b = 10;a ^= b; b ^= a; a ^= b; // 交换后 a=10, b=5```快速计算绝对值使用位运算可以快速计算一个整数的绝对值。```javaint a = -5;int abs = (a + (a >> 31)) ^ (a >> 31); // 5```---9.9 注意事项- **符号位**:在右移操作中,`>>` 会保留符号位,而 `>>>` 会用0填充。- **数据类型**:位运算符仅适用于整数类型(`byte`、`short`、`int`、`long`)。- **性能优化**:位运算在底层操作中非常高效,但过度使用可能会降低代码的可读性。11. `instanceof` 运算符的继承关系



`instanceof` 不仅可以检查对象是否是某个类的实例,还可以检查对象是否是某个类的子类的实例。

- **示例**:

```java

class Animal {} class Dog extends Animal {}

Animal myDog = new Dog(); System.out.println(myDog instanceof Dog); // true

System.out.println(myDog

instanceof Animal); // true

```


- **解释**:`instanceof` 运算符会检查对象的整个继承链,因此即使对象是子类的实例,它也会返回 `true`。


`instanceof` 使用注意点

`instanceof` 运算符在操作数为 `null` 时返回 `false`,而不是抛出异常。


- **示例**: ```java String str = null; if (str instanceof String) { // 结果为 false // ... } ```

- **解释**:`instanceof` 运算符在操作数为 `null` 时返回 `false`,因此可以安全地用于 `null` 检查。---


12. Lambda表达式与双冒号运算符

Lambda表达式

Java 8引入的Lambda表达式利用 `->` 运算符,使得函数式编程更加简洁。- **示例**: ```java List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); numbers.forEach(x -> System.out.println(x / 100.0)); ```

双冒号运算符

双冒号 `::` 用于方法引用,进一步简化Lambda表达式的写法。- **示例**: ```java List<String> strings = Arrays.asList("1", "2", "3"); List<Integer> numbers = strings.stream() .map(Integer::parseInt) .collect(Collectors.toList()); ```


Java位运算符使用经验



1. 按位与(`&`):

用于快速判断某个整数的特定位是否为1。 ```java int a = 5; // 0101 boolean isBitSet = (a & 1) != 0; // 判断最低位是否为1 ```2. 按位或(`|`):

用于将多个标志位组合成一个整数。 ```java int READ = 1, WRITE = 2, EXECUTE = 4; int permissions = READ | WRITE; // 组合权限 ```3. 按位异或(`^`):

用于交换两个变量的值。 ```java int a = 5, b = 10; a ^= b; b ^= a; a ^= b; // 交换a和b的值 ```4. 左移(`<<`)和右移(`>>`):

用于快速乘以或除以2的幂。 ```java int a = 8; int b = a << 1; // 16,相当于a * 2 int c = a >> 1; // 4,相当于a / 2 ```5. 使用位运算代替乘除法: ```java int a = 10; int b = a << 1; // 20,相当于a * 2 int c = a >> 1; // 5,相当于a / 2 ```---


Java运算符其他注意点

Java 本身不支持用户自定义的运算符重载,但某些运算符在特定场景下已经“重载”了。例如:

`+` 运算符的重载- **字符串连接**:`+` 运算符在用于字符串时会被重载,用于字符串连接。 ```java String result = "Hello, " + "World!"; // 结果是 "Hello, World!" ```- **数值加法**:`+` 运算符用于数值加法。 ```java int sum = 5 + 3; // 结果是 8 ```


`+=` 运算符的重载- **字符串连接**:`+=` 运算符可以用于字符串连接。 ```java String str = "Hello"; str += " World!"; // 结果是 "Hello World!" ```- **数值加法**:`+=` 运算符用于数值加法。 ```java int a = 5; a += 3; // 结果是 8 ```

`==` 和 `!=` 运算符的重载- **引用比较**:`==` 和 `!=` 运算符用于比较对象的引用。 ```java String s1 = new String("hello"); String s2 = new String("hello"); System.out.println(s1 == s2); // false,比较的是引用 ```- **数值比较**:`==` 和 `!=` 运算符用于比较数值。 ```java int a = 5, b = 5; System.out.println(a == b); // true,比较的是值 ```---


2. 自动装箱与拆箱

Java 提供了自动装箱(Autoboxing)和拆箱(Unboxing)功能,使得基本数据类型和其对应的包装类可以无缝转换。这在使用运算符时非常有用。自动装箱通过 valueOf() 方法实现,自动拆箱通过 xxxValue() 方法实现。自动装箱:


将基本数据类型自动转换为包装类。 ```java Integer a = 5; // 自动装箱,等价于 Integer a = Integer.valueOf(5); ```

自动拆箱:

将包装类自动转换为基本数据类型。 ```java int b = a; // 自动拆箱,等价于 int b = a.intValue(); ```- **运算符中的自动拆箱**: ```java Integer a = 10, b = 20; int sum = a + b; // 自动拆箱后计算 ```---


3. 字符串连接的性能优化


虽然 `+` 运算符可以用于字符串连接,但在大量字符串拼接时,性能较差。Java 提供了 `StringBuilder` 和 `StringBuffer` 来优化字符串拼接。- **使用 `+` 运算符**: ```java String result = "Hello, " + "World!"; // 适用于少量字符串拼接 ```- **使用 `StringBuilder`**: ```java StringBuilder sb = new StringBuilder(); sb.append("Hello, ").append("World!"); String result = sb.toString(); // 适用于大量字符串拼接 ```


总结

Java中的运算符规则包括贪心规则、优先级、结合性、类型转换规则、短路规则等。理解这些规则可以帮助开发者编写更高效、更健壮的代码,并避免因运算符使用不当而导致的错误。

在实际编程中,建议使用括号明确表达式的优先级,以提高代码的可读性和可维护性。同时,掌握运算符的巧妙使用经验可以进一步提升代码的性能和简洁性。

关注一下吧



相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 &quot;小贱贱&quot;韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...