JavaSE——运算符

1. 概念

运算符是一种用于执行特定操作的符号或关键字。在编程中,运算符用于对变量、常量和表达式进行操作,以产生一个结果。

作为一门计算机语言, Java 也提供了一套丰富的运算符来操纵变量。 Java 中运算符可分为以下:算术运算符 关系运算符 逻辑运算符位运算符移位运算符以及条件运算符等。

2. 算术运算符(+、-、*、/)

 2.1 基本四则运算符:加减乘除模(+ - * / %) 

int a = 2;
int b = 1;
System.out.println(a + b); // 3
System.out.println(a - b); // 1
System.out.println(a * b); // 2
System.out.println(a / b); // 2
System.out.println(a % b); // 0 --->模运算相当于数学中除法的余数

注意

  • 都是二元运算符,使用时必须要有左右两个操作数

  • int / int 结果还是int类型,而且会向下取整
        int a = 3;int b = 2;
// 在数学中应该是1.5 但是在Java中输出结果为1 会向下取整,即小数点之后全部舍弃掉了System.out.println(a / b);
// 如果要得到数学中的结果,可以使用如下方式double d = a*1.0 / b;System.out.println(d);}

  • 做除法和取模时,右操作数不能为0

  • % 不仅可以对整型取模,也可以对 double 类型取模,但是没有意义,一般都是对整型取模的
  • 两侧操作数类型不一致时,向类型大的提升
     System.out.println(1+0.2);// +的左侧是int,右侧是double,在加之前int被提升为double// 故:输出1.2


     

    2.2  增量运算符 += -= *= %=

    该种类型运算符操作完成后,会将操纵的结果赋值给左操作数。
            int a = 1;a += 2; // 相当于 a = a + 2System.out.println(a); // 输出3a -= 1; // 相当于 a = a - 1System.out.println(a); // 输出2a *= 3; // 相当于 a = a * 3System.out.println(a); // 输出6a /= 3; // 相当于 a = a / 3System.out.println(a); // 输出2a %= 3; // 相当于 a = a % 2System.out.println(a); // 输出2

    注意:只有变量才能使用该运算符,常量不能使用。

    2.3 自增/自减运算符 ++ --

    ++是给变量的值+1,--是给变量的值-1。
            int a = 1;a++; // 后置++ System.out.println(a++); // 注意:后置++是先使用变量原来值,表示式结束时给变量+1,因此输出2System.out.println(a); // 输出3++a; // 前置++ System.out.println(++a); // 注意:前置++是先给变量+1,然后使用变量中的值,因此输出5System.out.println(a); // 输出5// --操作符给操作-1,与++含义类似
    注意
    • 如果单独使用,【前置++】和【后置++】没有任何区别
    • 如果混合使用,【前置++】先+1,然后使用变量+1之后的值,【后置++】先使用变量原来的值,表达式结束时给变量+1
    • 只有变量才能使用自增/自减运算符,常量不能使用,因为常量不允许被修改

 3. 关系运算符

关系运算符主要有六个 : ==  !=  <  >  <=  >= ,其计算结果是 true 或者 false

        int a = 10;int b = 20;System.out.println(a == b); // falseSystem.out.println(a != b); // trueSystem.out.println(a < b); // trueSystem.out.println(a > b); // falseSystem.out.println(a <= b); // trueSystem.out.println(a >= b); // false

注意:

  • 在Java中 = 表示赋值,要与数学中的含义区分 ; 在Java中 == 表示相等
  • 当需要多次判断时,不能连着写,比如:3 < a < 5Java程序与数学中是有区别的

4. 逻辑运算符 

逻辑运算符主要有三个 : && 、 || 、 ! ,运算结果都是 boolean  类型。

4.1 逻辑与 (&&)

语法规则:表达式 1 && 表达式 2 ,左右表达式必须是  boolean  类型的结果。
两个表达式都为真,结果才是真,只要有一个是假,结果就是假。

表格表示如下 :

             表达式1            表达式2                结果
              真                真                  真
              真                假                  假
              假                真                  假
              假                假                  假

 代码表示如下:

        int a = 1;int b = 2;System.out.println(a == 1 && b == 2); // 左为真 且 右为真 则结果为真System.out.println(a == 1 && b > 10); // 左为真 但 右为假 则结果为假System.out.println(a > 10 && b == 2); // 左为假 但 右为真 则结果为假System.out.println(a > 10 && b > 10); // 左为假 且 右为假 则结果为假

 运行结果如下:

4.2 逻辑或(||)

语法规则:表达式 1 || 表达式 2 ,左右表达式必须是 boolean 类型的结果。

两个表达式都为假,结果才是假,只要有一个是真,结果就是真。

表格表示如下:

             表达式1            表达式2                结果
              真                真                  真
              真                假                  真
              假                真                  真
              假                假                  假

代码表示如下:

        int a = 1;int b = 2;System.out.println(a == 1 || b == 2); // 左为真 且 右为真 则结果为真System.out.println(a == 1 || b > 10); // 左为真 但 右为假 则结果为真System.out.println(a > 10 || b == 2); // 左为假 但 右为真 则结果为真System.out.println(a > 10 || b > 10); // 左为假 且 右为假 则结果为假

运行结果如下:

4.3 逻辑非( !)

语法规则 ! 表达式
真变假,假变真。

 表格表示如下:

            表达式2                结果
                真                  假
                假                  真

代码表达如下:

        int a = 1;System.out.println(!(a == 1)); // a == 1 为true,取个非就是falseSystem.out.println(!(a != 1)); // a != 1 为false,取个非就是true

运行结果如下:

4.4 短路求值

&& || 遵守短路求值的规则:
对于 && , 如果 左侧表达式值为 false, 则表达式结果一定是 false, 无需计算右侧表达式 .
对于 ||, 如果 左侧表达式值为 true, 则表达式结果一定是 true, 无需计算右侧表达式 .
代码表示如下:
        System.out.println(10 > 20 && 10 / 0 == 0); // 打印 falseSystem.out.println(10 < 20 || 10 / 0 == 0); // 打印 true

运行结果如下:

5. 位运算符

位运算符主要有四个 : & 、| 、~ 、^ ,除 ~ 是一元运算符外,其余都是二元运算符。
位操作表示 按二进制位运算 . 计算机中都是使用二进制来表示数据的 (01 构成的序列 ), 按位运算就是在按照二进制位的每一位依次进行计算.

5.1 按位与(&)

如果两个二进制位都是 1, 则结果为 1, 否则结果为 0.

代码如下:

        int a = 3;int b = 5;System.out.println(a & b);

运行结果如下:

5.2 按位或( | )

如果两个二进制位都是 0, 则结果为 0, 否则结果为 1.

 代码如下:

        int a = 3;int b = 5;System.out.println(a | b);

运行结果如下:

注意 : & | 的操作数为整数 (int, short, long, byte) 的时候 , 表示按位运算 , 当操作数为 boolean 的时候 , 表示逻辑运算.

5.3 按位异或( ^ )

如果两个数字的二进制位相同, 则结果为 0, 相异则结果为 1.

 代码如下:

        int a = 3;int b = 5;System.out.println(a ^ b);

运行结果如下:

注意:如果两个数相同,则异或的结果为 0。

5.4 按位取反( ~ )

如果该位为 0 则转为 1, 如果该位为 1 则转为 0
 
代码如下:
        int a = 0xf;System.out.printf("%x\n", ~a);

运行结果如下:

6. 移位运算符

移位运算符有三个 : << 、>> 、>>> ,都是二元运算符,且都是按照二进制比特位来运算的。

6.1 左移运算符(<<)

最左侧位舍弃, 最右侧补 0.  

代码如下:

         int a = 5;System.out.println(5<<1);

运行结果如下:

注意:向左移位时,丢弃的是符号位,因此正数左移可能会编程负数。

6.2 右移运算符(>>)

最右侧位舍弃, 最左侧补符号位(正数补0, 负数补1)。
 

代码如下:

        int a = 5;System.out.println(5>>1);

 运行结果如下;

6.3 无符号右移运算符(>>>)

最右侧位舍弃, 最左侧补 0.
 
代码如下:
        int a = 5;System.out.println(5>>>1);

运行结果如下:

注意 :
1. 左移 1 , 相当于原数字 * 2. 左移 N , 相当于原数字 * 2 N 次方 .
2. 右移 1 , 相当于原数字 / 2. 右移 N , 相当于原数字 / 2 N 次方 .
3. 由于计算机计算移位效率高于计算乘除 , 当某个代码正好乘除 2 N 次方的时候可以用移位运算代替 .
4. 移动负数位或者移位位数过大都没有意义 .

7. 条件运算符

条件运算符只有一个 :
表达式1 ? 表达式2 : 表达式3
当 表达式1 的值为 true 时, 整个表达式的值为 表达式2 的值;
当 表达式1 的值为 false 时, 整个表达式的值为 表达式3 的值.
也是 Java 中唯一的一个 三目运算符 , 是条件判断语句的简化写法 .
代码如下:
求两个数之间的最大值
        int a = 1;int b = 2;int max = a > b ? a : b;System.out.println(max);

运行结果如下:

注意

1. 表达式 2 和表达式 3 的结果要是同类型的,除非能发生类型隐式类型转换

2. 表达式不能单独存在,其产生的结果必须要被使用。

 

8. 运算符的优先级

在一条表达式中,各个运算符可以混合起来进行运算,但是运算符的优先级不同,比如: * / 的优先级要高于 + 和 - ,有些情况下稍不注意,可能就会造成很大的麻烦。
例如:
 
        // 求a和b的平均值int a = 10;int b = 20;int c = a + (b - a) >> 1;System.out.println(c);
上述表达式中,由于 + 的优先级要高于 >> , 因此 a 先和 b-a 的结果做加法,整体为 20 ,最后再进行右移,因此结果为10

不过,具体的规则我们不必记忆. 在可能存在歧义的代码中加上括号即可.
例如:

        // 求a和b的平均值int a = 10;int b = 20;int c = a + ((b - a) >> 1);System.out.println(c);

运行结果如下:

 

本文是作者学习后的总结,如果有什么不恰当的地方,欢迎大佬指正!!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/792234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电商系列之促销

> 插&#xff1a;AI时代&#xff0c;程序员或多或少要了解些人工智能&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 坚持不懈&#xff0c;越努力越幸运&#xff0c;大家…

算法沉淀——动态规划篇(子数组系列问题(下))

算法沉淀——动态规划篇&#xff08;子数组系列问题&#xff08;下&#xff09;&#xff09; 前言一、等差数列划分二、最长湍流子数组三、单词拆分四、环绕字符串中唯一的子字符串 前言 几乎所有的动态规划问题大致可分为以下5个步骤&#xff0c;后续所有问题分析都将基于此 …

CSS之第一个CSS样式和CSS选择符

前端这些博客&#xff0c;我觉得都是固定的语法&#xff0c;故而不会以过多的文字进行描述&#xff0c;本系列博文均以实例和代码介绍的方式进行&#xff0c;主要按照代码进行。不会以过多的文字描述。 第一个CSS样式 <!DOCTYPE html> <html lang"en">…

【JavaEE初阶系列】——文件操作 IO 之 文件系统操作

目录 &#x1f4dd;认识文件 &#x1f6a9;树型结构组织 和 目录 &#x1f388;绝对路径和相对路径 &#x1f6a9;文件类型 &#x1f4dd;文件系统操作 &#x1f388;File 概述 &#x1f388;File类的使用 1. 绝对路径 vs 相对路径 2. 路径分隔符 3. 静态成员变量 4…

【C语言】翻译环境与运行环境

一、前言 在我们学习C语言的时候&#xff0c;第一个接触的程序就是&#xff1a;在屏幕上打印” hello word! “&#xff0c;可当时的我们却未去深入的理解与感悟&#xff0c;一个程序代码是如何运行的&#xff1b;而这一期的博客&#xff0c;则是带着我们&#xff0c;通过C代码…

mac电脑安装redis教程

1、下载地址 Download | RedisRedisYou can download the last Redis source files here. For additional options, see the Redis downloads section below.Stable (7.2)Redis 7.2 …https://redis.io/download/#redis-downloads 2、安装 2.1 解压下载后的压缩文件 2.2 进入…

Vulnhub:WESTWILD: 1.1

目录 信息收集 arp nmap nikto whatweb WEB web信息收集 dirmap enm4ulinux sumbclient get flag1 ssh登录 提权 横向移动 get root 信息收集 arp ┌──(root㉿ru)-[~/kali/vulnhub] └─# arp-scan -l Interface: eth0, type: EN10MB, MAC: 0…

LeetCode-236. 二叉树的最近公共祖先【树 深度优先搜索 二叉树】

LeetCode-236. 二叉树的最近公共祖先【树 深度优先搜索 二叉树】 题目描述&#xff1a;解题思路一&#xff1a;递归判断解题思路二&#xff1a;0解题思路三&#xff1a;0 题目描述&#xff1a; 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖…

linux操作系统的进程状态

这个博客只是为了自己复习用的&#xff01;&#xff01;&#xff01; 冯诺依曼体系结构 计算机是由一个一个硬件组成的 输入设备&#xff1a;键盘&#xff0c;鼠标&#xff0c;扫描仪&#xff0c;写板等等 中央处理器&#xff08;CPU&#xff09;:含有运算器和控制器等 输出单…

【算法练习】27:冒泡排序学习笔记

一、冒泡排序的算法思想 原理&#xff1a;以升序为例&#xff0c;冒泡排序通过从左往右连续比较相邻元素&#xff0c;当发现左边比右边大就交换元素。从左往右依次比较完称为“一轮”&#xff0c;每轮结束之后就会固定一个元素。 时间复杂度&#xff1a;2层循环&#xff0c;所以…

不讲概念,讲实操,mysql 分表模糊查询、分页查询 及 merge 表的使用

1.Mysql merge合并表的要求 1.合并的分表必须是 MyISAM 引擎&#xff0c;MyISAN引擎是不支持事务的。2.Merge表只保证合表后数据唯一性&#xff0c;合表前的数据可能会存在重复。3.表的结构必须一致&#xff0c;包括索引、字段类型、引擎和字符集。4.删除 tb_member1 分表正确…

Python实现BOA蝴蝶优化算法优化卷积神经网络分类模型(CNN分类算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 蝴蝶优化算法(butterfly optimization algorithm, BOA)是Arora 等人于2019年提出的一种元启发式智能算…

[技术闲聊]我对电路设计的理解(三)

终于可以独立做项目了&#xff0c;是不是很激动&#xff0c;是不是为自己骄傲和自豪&#xff0c;应该的&#xff0c;奋斗那么久不就是为了站在山巅看看四周的风景嘛&#xff01; 虽说山外还有山&#xff0c;但是此刻就在脚下的山巅上&#xff0c;怡然自得都是不过分的&#xff…

LLM端侧部署系列 | 如何将阿里千问大模型Qwen部署到手机上?实战演示(下篇)

引言 简介 编译Android可用的模型 转换权重 生成配置文件 模型编译 编译apk 修改配置文件 绑定android library 配置gradle 编译apk 手机上运行 安装 APK 植入模型 效果实测 0. 引言 清明时节雨纷纷&#xff0c;路上行人欲断魂。 小伙伴们好&#xff0c;我是《小…

9.动态规划——4.最长公共子序列(动态规划类的算法题该如何解决?)

例题——最长公共子序列(一) 分析 设最长公共子序列 d p [ i ] [ j ] dp[i][j] dp[i][j]是 S 1 S_1 S1​的前 i i i个元素&#xff0c;是 S 2 S_2 S2​的前 j j j个元素&#xff0c;那么有&#xff1a; 若 S 1 [ i − 1 ] S 2 [ i − 1 ] S_1[i-1]S_2[i-1] S1​[i−1]S2​[…

leetcode刷题-代码训练营-第7章-回溯算法1

回溯法模板 void backtracking(参数) {if (终止条件) {存放结果;return;}for (选择&#xff1a;本层集合中元素&#xff08;树中节点孩子的数量就是集合的大小&#xff09;) {处理节点;backtracking(路径&#xff0c;选择列表); // 递归回溯&#xff0c;撤销处理结果} }理解 从…

小林coding图解计算机网络|基础篇02|键入网址到网页显示,期间发生了什么?

小林coding网站通道&#xff1a;入口 本篇文章摘抄应付面试的重点内容&#xff0c;详细内容还请移步&#xff1a;小林coding网站通道 文章目录 孤单小弟——HTTP真实地址查询——DNS指南好帮手——协议栈可靠传输——TCP远程定位——IP两点传输——MAC出口——网卡送别者——交…

Linux是什么,该如何学习

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《Linux &#xff1a;从菜鸟到飞鸟的逆袭》 &#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、Linux的起源与发展 2、Linux在现代计算机领域…

Golang 内存管理和垃圾回收底层原理(一)

一、这篇文章我们来聊聊Golang内存管理和垃圾回收&#xff0c;主要注重基本底层原理讲解&#xff0c;进一步实战待后续文章 1、这篇我们来讨论一下Golang的内存管理 先上结构图 从图我们来讲Golang的基本内存结构&#xff0c;内存结构可以分为&#xff1a;协程缓存、中央缓存…

Excel 粘贴回筛选后的单元格不能完全粘老是少数据 ,有些单元格还是空的

环境&#xff1a; excel2021 Win10专业版 问题描述&#xff1a; excel 粘贴回筛选后的单元格不能完全粘老是少数据 有些单元格还是空的 复制选择筛选后A1-A10单元格 &#xff0c;定位条件&#xff09;&#xff08;仅可见单元格&#xff09;来访问&#xff0c;或者你可以使用…