【JavaSE重点知识归纳】第3节:运算符(算术、关系、逻辑、位、移位、优先级)

news2024/11/24 10:49:40

目录

一:什么是运算符

二:算术运算符

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

2.增量运算符(+=、-=、*=、%=)

3.自增/自减运算符(++、--)

三:关系运算符

四:逻辑运算符(重点)

五:位运算符

六:移位运算符

七:条件运算符

八:运算符的优先级


一:什么是运算符

        对操作数进行操作的符号,不同运算符操作的含义不同。

二:算术运算符

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

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

(2)int/int 结果还是int类型,而且会向下取整

(3)做除法和取模时,右操作数不能为0,会算术异常报错

System.out.println(1/0) ;//error
System.out.println(1%0) ;//error

(4)%不仅可以对整型取模,也可以对double类型取模

System.out.println(12.5%2.0) ;//2.5

(5)当两侧操作数不一样是,会向类型大的提升

System.out.println(1+1.1) ;//会提升为double类型
2.增量运算符(+=、-=、*=、%=)

        该运算符可以帮我们进行类型转换,将操作的结果赋值给左操作数

int a=10;
a=(int)(a+1.1);//a+1.1为double,但是a为int类型,需要强制转换为int
a+=1.1;//增量运算符可以自动转换为类型大的,不需要转换
3.自增/自减运算符(++、--)

(1)++是给变量的值+1,--是给变量-1

(2)如果单独使用,【前置++】和【后置++】没有任何区别

(3)如果混合使用,【前置++】先+1,然后使用变量+1之后的值;【后置++】先使用原来变量的值,表达式结束时给变量+1

int a=1;
a++;//a=2
System.out.println(a++);//后置++,先使用,输出2,即a=2,然后+1
System.out.println(a);//a=3

三:关系运算符

(1)关系运算符有6个,==,!=,<,>,<= ,>= 

(2)在Java当中,=表示赋值,==表示相等

(3)当需要多次判断是,不要连着写,比如:3<a<5(×)。当a=2时,3<a为false,false<5不能比

四:逻辑运算符(重点)

        逻辑运算符有三个:&&,||,!,运算结构都是boolean类型

(1)逻辑与&&:表达式1&&表达式2,左右表达式必须是boolean类型

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

(2)逻辑或||:表达式1&&表达式2,左右表达式必须是boolean类型

左右表达式至少有一个为真,则结果为真

(3)逻辑非!:!表达式

真变假,假变真

(4)短路求值

System.out.println(1>2&&1/0==0);//打印false
//对于&&:表达式1为假,就不会执行表达式2了
System.out.println(1<2&&1/0==0);//打印true
//对于||:表达式1为真,就不会执行表达式2了

//&和|如果表达式结果为boolean时,也表示逻辑运算,但与&& ||相比时,他们不支持短路求值

五:位运算符

        数据操作的最小单位是比特,最小的存储单位是字节

位操作表示按二进制位运算,主要有4个:& ,|,~,^

(1)按位与&:如果两个二进制位都是1,则结果也为1,否则为0

(2)按位或|:两个二进制位都是0,则结果为0,否则结果为1

(3)按位取反~:0转1,1转0

int a=0xf;//表示16进制 ,f为十进制的15
System.out.printf("%x\n",a);
System.out.printf("%x\n",~a);//用16进制打印
结果:
f
fffffff0

(4)按位异或^:两个数字的二进制位相同为0,相异为1

a^a=0  a^0=a

六:移位运算符

(1)左移<<:最左侧位不要了,最右侧补0【左移一位,相当于原数字*2】

向左移位时,丢弃的是符号位,因此正数左移可能会变成负数

(2)右移>>:最右侧位不要了,最左侧补符号位(正数补0,负数补1)【右移一位,相当于原数字/2】

(3)无符号右移>>>:最右侧位不要了,最左侧补0

(4)由于计算机计算移位效率高于计算乘除,当某个代码正好乘除2的N次方的时候可以用移位运算符代替

七:条件运算符

        条件运算符(也称三目运算符)只有一个:表达式1?表达式2:表达式3

当表达式1的值为true时,整个表达式的值为表达式2的值

当表达式1的值为false时,整个表达式的值为表达式3的值

八:运算符的优先级

(1)运算符之间是有优先级的,具体的规则我们不必记忆,在可能存在歧义的地方加括号即可

(2)要注意的是:&&优先级高于||

System.out.println(10>3||10<3&&10<3);//true
//加括号
System.out.println((10>3)||(10>3&&10<3));

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

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

相关文章

【Kafka专题】Kafka集群架构设计原理详解

目录 前言前置知识课程内容一、Kafka的Zookeeper元数据梳理1.1 zookeeper整体数据1.2 Controller Broker选举机制1.3 Leader Partition选举机制1.4 Leader Partition自动平衡机制*1.5 Partition故障恢复机制1.6 HW一致性保障-Epoch更新机制1.7 总结 学习总结感谢 前言 Kafka的…

R语言实现竞争风险模型(1)

#竞争风险模型 tmp <- data.frame(gene tiaoxuan[,5:6],OS.Time Train[,"Survival_months"], OS Train[,"CSS"],stringsAsFactors F) colnames(tmp) #方法1&#xff1a;riskregression library(riskRegression) fgr1<-FGR(Hist(OS.Time,OS)~gen…

K 个一组翻转链表(链表反转,固定长度反转)(困难)

优质博文&#xff1a;IT-BLOG-CN 一、题目 给你链表的头节点head&#xff0c;每k个节点一组进行翻转&#xff0c;请你返回修改后的链表。 k是一个正整数&#xff0c;它的值小于或等于链表的长度。如果节点总数不是k的整数倍&#xff0c;那么请将最后剩余的节点保持原有顺序。…

Android SELinux 参数语法介绍及基础分析

Android SELinux安全策略主要使用对象安全上下文的基础进行描述&#xff0c;通过主体和客体的安全上下文去定义主体是否有权限访问客体&#xff0c;称为TypeEnforcement 安全上下文&#xff08;Security Context&#xff09; SEAndroid中的安全上下文:共有4个部分组成分别为use…

STM32 定时器介绍--通用、高级定时器

目录 高级定时器 1.功能框图 1-时钟源 2-时基单元 3-输入捕获 4-输出比较 2.输入捕获的应用 3.输出比较的应用 4.初始化结构体 1-时基初始化结构体 2-输出比较结构体 3-PWM信号 周期和占空比的计算--以通用定时器为例 4-输入捕获结构体 5-断路和死区初始化结构体…

05. 机器学习入门 - 动态规划

文章目录 从一个案例开始动态规划 Hi, 你好。我是茶桁。 咱们之前的课程就给大家讲了什么是人工智能&#xff0c;也说了每个人的定义都不太一样。关于人工智能的不同观点和方法&#xff0c;其实是一个很复杂的领域&#xff0c;我们无法用一个或者两个概念确定什么是人工智能&a…

对一条Linux命令的解读(sed find egrep)

目录 1 sed -i的意义 2 $的作用 3 find . -type f的意义 4 -exec .... {} \;的意义 5 egrep -l的意义 6 综合以上 在前面的博客源码编译elfutils_金色熊族的博客-CSDN博客中&#xff0c;我使用了一条指令 sed -i s/-Werror//g $(find . -type f -exec egrep -l _no_Werr…

学信息系统项目管理师第4版系列15_资源管理基础

1. 项目资源 1.1. 实物资源 1.1.1. 着眼于以有效和高效的方式&#xff0c;分配和使用完成项目所需的实物资源 1.1.2. 包括设备、材料、设施和基础设施 1.2. 团队资源 1.2.1. 人力资源 1.2.2. 包含了技能和能力要求 2. 人力资源管理 2.1. 不仅是组织中最重要的资源之一&…

C语言结构体指针学习

结构体变量存放内存中&#xff0c;也有起始地址&#xff0c;定义一个变量来存放这个地址&#xff0c;那这个变量就是结构体指针&#xff1b; typedef struct mydata{int a1;int a2;int a3; }mydata;void CJgtzzView::OnDraw(CDC* pDC) {CJgtzzDoc* pDoc GetDocument();ASSERT…

【算法分析与设计】回溯法(上)

目录 一、学习要点1.1 回溯法1.2 问题的解空间1.3 0-1背包问题的解空间1.4 旅行售货员问题的解空间1.5 生成问题状态的基本方法 二、回溯法的基本思想三、回溯算法的适用条件四、递归回溯五、迭代回溯六、子集树与排列树七、装载问题八、批处理作业调度问题 一、学习要点 理解回…

Scala第十一章节

Scala第十一章节 1.模式匹配 2. Option 类型 3.偏函数 4.正则表达式 5.异常处理 6.提取器 7.案例&#xff1a;随机职业 scala总目录 文档资料下载

大数据Flink(九十五):DML:Window TopN

文章目录 DML:Window TopN DML:Window TopN Window TopN 定义(支持 Streaming):Window TopN 是一种特殊的 TopN,它的返回结果是每一个窗口内的 N 个最小值或者最大值。 应用场景

【C语言】模拟实现strstr

strstr这个库函数看到这个名字大概率猜不到这是什么函数&#xff0c; 但经过学习就可以很好的认识到这个函数 目录 介绍&#xff1a;模拟实现&#xff1a;思路&#xff1a;代码实现&#xff1a; 介绍&#xff1a; 可以看到此函数是用来寻找一个字符串中是否含有另一个字符串 代…

云安全之HTTP协议介绍补充

HTTP是一个基于TCP/IP通信协议来传递数据的协议&#xff0c;传输的数据类型为HTML文件、图片文件、查询结果等。HTTP协议一般用于B/S架构。浏览器作为HTTP客户端通过URL向HTTP服务端即WEB服务器发送所有请求。 URI、URL、URN HTTP使用统一资源标识符(Uniform Resource ldentif…

WebSocket实战之二协议分析

一、前言 上一篇 WebSocket实战之一 讲了WebSocket一个极简例子和基础的API的介绍&#xff0c;这一篇来分析一下WebSocket的协议&#xff0c;学习网络协议最好的方式就是抓包分析一下什么就都明白了。 二、WebSocket协议 本想盗一张网络图&#xff0c;后来想想不太好&#x…

ImportSelector使用详解

版权声明 本文原创作者&#xff1a;谷哥的小弟作者博客地址&#xff1a;http://blog.csdn.net/lfdfhl ImportSelector概述 利用Import和ImportSelector可将组件批量添加至IoC容器 ImportSelector案例 在此&#xff0c;介绍ImportSelector使用案例。 定义ImportSelector S…

Kotlin前置检测判断check,require,requireNotNull

Kotlin前置检测判断check&#xff0c;require&#xff0c;requireNotNull &#xff08;1&#xff09;check fun main(args: Array<String>) {val b falsecheck(b) {println("check $b")}println("end") } check监测到值非真时候&#xff0c;抛出一…

国庆作业day5

应用层&#xff1a;提供用户与网络应用程序之间的接口。表示层&#xff1a;负责数据的格式转换、加密和解密。会话层&#xff1a;负责建立、管理和终止会话。它提供会话控制和同步&#xff0c;允许应用程序之间建立连接和交换数据。传输层&#xff1a;提供端到端的连接。网络层…

【ppt技巧】给ppt文件设置带有密码的只读模式

有没有同学&#xff0c;想要给PPT文件设置修改权限&#xff0c;却没有找到功能&#xff0c;给PPT文件设置只读模式&#xff0c;没有密码设置的&#xff1f;今天给大家分享给PPT文件设置带有密码的只读模式&#xff08;修改权限&#xff09;。 打开PPT文件之后&#xff0c;将PP…

数据结构与算法课后题-第三章(顺序队和链队)

#include <iostream> //引入头文件 using namespace std;typedef int Elemtype;#define Maxsize 5 #define ERROR 0 #define OK 1typedef struct {Elemtype data[Maxsize];int front, rear;int tag; }SqQueue;void InitQueue(SqQueue& Q) //初始化队列 {Q.rear …