当前位置: 首页 > news >正文

【一步一步了解Java系列】:了解Java与C语言的运算符的“大同小异”

看到这句话的时候证明:此刻你我都在努力~

                                 加油陌生人~

个人主页:  Gu Gu Study                                                   ​​

专栏:一步一步了解Java

喜欢的一句话: 常常会回顾努力的自己,所以要为自己的努力留下足迹。

      如果喜欢能否点个赞支持一下,谢谢啦!

                                                                                                                            作者:小闭

目录

一、算术运算符

二、赋值运算符(增量,自增运算符)

三、关系运算符

四、逻辑运算符

五、位运算符

六、移位操作符


运算符的作用

在 Java 中,运算符具有以下主要作用:

计算机语言最基本的作用就是进行数学运算
 
1. 执行运算:如算术运算符(+、-、*、/等)用于进行数学计算。
2. 比较操作:比较运算符(如>、<、>=、<=等)用于比较两个值的大小关系。
3. 逻辑判断:逻辑运算符(&&、||、!等)用于组合和判断条件。
4. 赋值操作:赋值运算符(=)用于将值赋给变量。
5. 其他操作:还有一些特殊的运算符,如位运算符等,用于位操作等。

 


Java中各种运算符功能

Java 中的运算符可以分为以下几类:
 
1. 算术运算符:用于执行基本的数学运算,如加法、减法、乘法、除法和取模(取余)等。例如,+ 表示加法运算,- 表示减法运算。


2. 关系运算符:用于比较两个值的关系,如等于、不等于、大于、小于等。关系运算符返回布尔值(true 或 false),用于条件判断。例如,== 表示等于运算,< 表示小于运算。


3. 逻辑运算符:用于执行逻辑运算,如逻辑与、逻辑或和逻辑非等。逻辑运算符通常用于布尔值的操作,它们返回布尔结果。例如,&& 表示逻辑与,|| 表示逻辑或,! 表示逻辑非。


4. 赋值运算符:用于将值赋给变量,如 = 表示赋值运算,+= 表示加并赋值。


5. 自增和自减运算符:用于增加或减少变量的值,例如 ++ 表示自增,-- 表示自减。


6. 位运算符:用于对二进制位进行操作,如位与、位或、位异或、取反等。


7. 三目运算符:用于根据条件选择一个值。
 

一、算术运算符

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

int a = 20;
int b = 5;
System.out.println(a + b);   // 25System.out.println(a - b);    // 15System.out.println(a * b); // 100System.out.println(a / b); // 4System.out.println(a % b); // 0     模运算其实就是数学中除法的余数

注意: 

1.1 上面的都是算术运算符二元运算符,使用时必须要有左右两个操作数

1.2 关于类型转变: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);

 

1.3 取模时%右边的操作数不能为0否则就会报错

public static void main(String[] args) {int a=3/0;System.out.println("a = " + a);  //a = 1}

1.4 与C语言不同的是,Java中支持double类型数据进行取模运算 

public static void main(String[] args) {double a=66.6/1.1;System.out.println("a = " + a);                  }

1.5 类型的数据进行运算时类型会转变为类型较大的数据。        

public static void main(String[] args) {System.out.println(66.6/6);  //11.1}

二、赋值运算符(增量,自增运算符)

如下:

+= ,-= ,*=, %=,++,--

2.1 增量运算符

int a = 18;
a += 2; // 相当于 a = a + 2
System.out.println(a); // 输出20a -= 2; // 相当于 a = a - 2
System.out.println(a); // 输出16a *= 2; // 相当于 a = a * 2
System.out.println(a); // 输出36a /= 2; // 相当于 a = a / 2
ystem.out.println(a); // 输出9

 如上注释,增量运算符可以有效提高我们敲打吗的速度。

2.2 自增运算符

++为变量的值加1,--则是变量的值减1

但是存在前置和后置的区别,如下为前置++,和后置++的区别代码

int a = 1;
a++; // 后置++ 表示给a的值加1,此时a的值为2
System.out.println(a++); // 注意:后置++是先使用变量原来值,表示式结束时给变量+1,因此输出2
System.out.println(a); // 输出3
++a; // 前置++ 表示给a的值加1
System.out.println(++a); // 注意:前置++是先给变量+1,然后使用变量中的值,因此输出5
System.out.println(a); // 输出5
// --操作符给操作-1,与++含义类似

 


三、关系运算符

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

关系运算符与数学的比较一模一样。

3.1 与C语言不同的是,他们的结果并不是1和0,Java中不能用0和1表示事件的真假。其返回的只有true 或者 false 。

四、逻辑运算符

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

4.1 && 运算符  “一个为假则结果为假”

表达式1                                    表达式2                                       结果

真                                                 真                                                真

真                                                 假                                                假

假                                                 真                                                假

假                                                 假                                                假

 


4.2  || 操作符 “一个为真则结果为真”

表达式1                                    表达式2                                       结果

真                                                 真                                                真

真                                                 假                                                真

假                                                 真                                                真

假                                                 假                                                假


4.3   ! 逻辑非

即把真(true)变为假(false),把假(false变为真(true)。

4.4 短路求值

对于 && , 如果左侧表达式值为 false, 则表达式结果一定是 false, 无需计算右侧表达式.

对于 ||, 如果左侧表达式值为 true, 则表达式结果一定是 true, 无需计算右侧表达式.

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

如下代码:

System.out.println(18 > 20 && 10 / 0 == 0); // 打印 falseSystem.out.println(18 < 20 || 10 / 0 == 0); // 打印 true

 在这里后面的操作 10/0,并未被计算也就是程序没有出现分母为0的异常警告/


五、位运算符

Java 与C语言数据存储的最小单位是字节,而数据操作的最小单位是比特位. 字节是最小的存储单位,每个字节是由8个二 进制比特位组成的,多个字节组合在一起可以表示各种不同的数据。

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


5.1 按位与 &

在计算机中数据的储存都是以0,1的形式进行储存,而按位与 &就可以让两个数据进行运算

进行按位与 & 运算时:如果两个二进制位都是 1, 则结果为 1, 否则结果为 0.

public static void main(String[] args) {int a=10;int b=3;System.out.println(a&b);  //打印结果为2}

 为什么打印2呢?,首先我们列出两个数的补码。

int a =00000000000000000000000000001010

int b =00000000000000000000000000000011

进行按位与&时:如果两个二进制位都是 1, 则结果为 1, 否则结果为 0.

 经过按位与&后得到 :00000000000000000000000000000010


5.2 按位或

在计算机中数据的储存都是以0,1的形式进行储存,而按位或 | 就可以让两个数据进行运算.

进行按位或 | 运算时 :如果两个二进制位都是 0, 则结果为 0, 否则结果为 1.

public static void main(String[] args) {int a=10;int b=3;System.out.println(a|b);  //11}

 

为什么打印11呢?,首先我们列出两个数的补码。

int a =00000000000000000000000000001010

int b =00000000000000000000000000000011

进行按位或 | 运算时 :如果两个二进制位都是 0, 则结果为 0, 否则结果为 1.

经过按位或| 得到: 00000000000000000000000000001011 即十进制的11


六、移位操作符

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

如:

int a = 10;
System.out.println( a << 1);
// 运行结果20

 6.1  <<左移操作符

左移规则:最左侧位不要了, 最右侧补 0.

int a = 10;
System.out.println( a << 1);
// 运行结果20

就像上面的代码,我们先把int a的补码列出来

int a =00000000000000000000000000001010   左移规则:最左侧位不要了, 最右侧补 0.

经过左移1位后得到:00000000000000000000000000010100  即十进制的20


6.2  >>右移操作符

 右移规则:最右侧位不要了, 最左侧补符号位(正数补0, 负数补1)

int a = 10;
System.out.println( a >> 1);
// 运行结果5

 老样子列出int a的补码:

int a =00000000000000000000000000001010  

右移规则:最右侧位不要了, 最左侧补符号位(正数补0, 负数补1)

然后右移一位得到:00000000000000000000000000000101 即十进制的5.


6.3 无符号右移

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

 与普通右移不同的就是无符号右移后得到的肯定是一个正数。即使是负数右移

 public static void main(String[] args) {int a = -10;System.out.println( a >>> 1);
// 运行结果20}

 列出-10的补码:

原码:int a =10000000000000000000000000001010  

反码:          11111111111111111111111111111110101

补码:          11111111111111111111111111111110110

无符号右移规则:最右侧位不要了, 最左侧补0

然后右移一位得到:01111111111111111111111111111111011  

转化为原码打印即:上面的结果。


 七、三目运算符

形式为:表达式1 表达式2 : 表达式3

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

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

注意:

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

public static void main(String[] args) {int a=10;double b=12.6;int c1;double c2;c2=a>b?a:b;c1=a>b?a:b;}

如图:c2是可以发生转换的,所以可以使用。c1则不行。 

 

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


文章已到末尾,喜欢的话点个赞吧。

 

相关文章:

【一步一步了解Java系列】:了解Java与C语言的运算符的“大同小异”

看到这句话的时候证明&#xff1a;此刻你我都在努力~ 加油陌生人~ 个人主页&#xff1a; Gu Gu Study ​​ 专栏&#xff1a;一步一步了解Java 喜欢的一句话&#xff1a; 常常会回顾努力的自己&#xff0c;所以要为自己的努…...

ICSE docker related research

ICSE 2024 Empirical Study of the Docker Smells Impact on the Image Size Docker 气味对镜像大小影响的实证研究 Docker 是一种广泛采用的打包和部署应用程序的工具&#xff0c;它利用 Dockerfile 来构建镜像。然而&#xff0c;创建最佳的 Dockerfile 可能具有挑战性&…...

【C++】学习笔记——多态_1

文章目录 十二、继承8. 继承和组合 十三、多态1. 多态的概念2. 多态的定义和实现虚函数重写的两个特殊情况override 和 final 3. 多态的原理1. 虚函数表 未完待续 十二、继承 8. 继承和组合 我们已经知道了什么是继承&#xff0c;那组合又是什么&#xff1f;下面这种情况就是…...

C++map容器关联式容器

Cmap 1. 关联式容器 vector、list、deque、forward_list(C11)等STL容器&#xff0c;其底层为线性序列的数据结构&#xff0c;里面存储的是元素本身&#xff0c;这样的容器被统称为序列式容器。而map、set是一种关联式容器&#xff0c;关联式容器也是用来存储数据的&#xff0…...

TS-抽象类和静态成员

目录 1&#xff0c;抽象类1&#xff0c;为什么需要抽象类2&#xff0c;抽象成员3&#xff0c;设计模式-模板模式 2&#xff0c;静态成员1&#xff0c;什么是静态成员2&#xff0c;设计模式-单例模式 1&#xff0c;抽象类 1&#xff0c;为什么需要抽象类 有时&#xff0c;某个…...

SharePoint 使用renderListDataAsStream方法查询list超过5000时的数据

问题&#xff1a; 当SharePoint List里的数据超过5000时&#xff0c;如果使用常用的rest api去获取数据&#xff0c;例如 await this.sp.web.lists.getByTitle(Document Library).rootFolder.files.select(*, listItemAllFields).expand(listItemAllFields).filter(listItemA…...

2024042001-计算机网络 - 物理层

计算机网络 - 物理层 计算机网络 - 物理层 通信方式带通调制 通信方式 根据信息在传输线上的传送方向&#xff0c;分为以下三种通信方式&#xff1a; 单工通信&#xff1a;单向传输半双工通信&#xff1a;双向交替传输全双工通信&#xff1a;双向同时传输 带通调制 模拟信号…...

通过java将数据导出为PDF,包扣合并单元格操作

最近项目中需要将查询出来的表格数据以PDF形式导出&#xff0c;并且表格的形式包含横向行与纵向列的单元格合并操作&#xff0c;导出的最终效果如图所示&#xff1a; 首先引入操作依赖 <!--导出pdf所需包--><dependency><groupId>com.itextpdf</groupId&…...

Java内存模式以及volatile关键字的使用

1.Java内存模型 &#xff08;1&#xff09;Java 内存模型&#xff08;Java Memory Model&#xff0c;简称 JMM&#xff09;&#xff0c;它是一个抽象的概念&#xff0c;JMM是和多线程相关的&#xff0c;它是一组规范&#xff0c;描述了一组规则&#xff0c;定义了多线程对共享…...

每日5题Day3 - LeetCode 11 - 15

每一步向前都是向自己的梦想更近一步&#xff0c;坚持不懈&#xff0c;勇往直前&#xff01; 第一题&#xff1a;11. 盛最多水的容器 - 力扣&#xff08;LeetCode&#xff09; class Solution {public int maxArea(int[] height) {//这道题比较特殊&#xff0c;因为两边是任意…...

路由器、交换机和网卡

大家使用VMware安装镜像之后&#xff0c;是不是都会考虑虚拟机的镜像系统怎么连上网的&#xff0c;它的连接方式是什么&#xff0c;它ip是什么&#xff1f; 路由器、交换机和网卡 1.路由器 一般有几个功能&#xff0c;第一个是网关、第二个是扩展有线网络端口、第三个是WiFi功…...

腾讯开源混元DiT文生图模型,消费级单卡可推理

节前&#xff0c;我们组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、今年参加社招和校招面试的同学。 针对大模型技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备面试攻略、面试常考点等热门话题进行了深入的讨论。 总结链接…...

shell脚本基础(if/else结构)

命令是双向选择语句&#xff0c;当用户执行脚本时如果不满足if后的表达式也会执行else后的命令&#xff0c;所以有很好的交互性。其结构为&#xff1a; if expression1 then command … command else command … command fi vim ifelse_exam.sh #ifelse_exam.sh #!/bin/bashec…...

万字长文破解 AI 图片生成算法-Stable diffusion (第一篇)

想象一下&#xff1a;你闭上眼睛&#xff0c;脑海中构思一个场景&#xff0c;用简短的语言描述出来&#xff0c;然后“啪”的一声&#xff0c;一张栩栩如生的图片就出现在你眼前。这不再是科幻小说里才有的情节&#xff0c;而是Stable Diffusion——一种前沿的AI图片生成算法—…...

Linux---编辑器vim的认识与简单配置

前言 我们在自己的电脑上所用的编译软件&#xff0c;就拿vs2022来说&#xff0c;我们可以在上面写C/C语言、python、甚至java也可以在上面进行编译&#xff0c;这种既可以用来编辑、运行编译&#xff0c;又可以支持很多种语言的编译器是一种集成式开发环境&#xff0c;集众多于…...

lucene中Collector类、CollectorManager类区分和用法

我的lucene版本是9.10.0&#xff0c;请说明Collector类、CollectorManager类区分和用法&#xff0c;尽量详细点 在 Lucene 9.10.0 中&#xff0c;Collector 类和 CollectorManager 类都是用于搜索结果的收集和处理 Collector 类 Collector 类是一个接口&#xff0c;用于收集…...

Android之给Button上添加按压效果

一、配置stateListAnimator参数实现按压效果 1、按钮控件 <Buttonandroid:id"id/mBtnLogin"android:layout_width"match_parent"android:layout_height"48dp"android:background"drawable/shape_jfrb_login_button"android:state…...

python EEL + vue3.js 项目中如何把组件中的函数提升为全局函数

eel官方示例中暴露的js函数是全局函数&#xff0c;vue中的自定义函数作用域通常都是组件范围内。要让eel.js调用&#xff0c;需要将其升为全局可用。 一般方法有 app.config.globalProperties 或 mixin等。 main.js //main.jsimport { createApp } from vue import App from…...

sqli-labs靶场第十四关

目录 1&#xff1a;分析 找闭合符&#xff1a; 2&#xff1a;开始注入 报错注入&#xff1a; 注入数据库名&#xff1a; 注入表名&#xff1a; 注入列名&#xff1a; 注入具体值&#xff1a; 1&#xff1a;分析 经过我们的实验发现当我们输入的密码后面存在双引号时会报…...

【C语言】6.C语言VS实用调试技巧(1)

文章目录 1.什么是 bug2.什么是调试&#xff08;debug&#xff09;&#xff1f;3.Debug 和 Release4.VS调试快捷键4.1 环境准备4.2 调试快捷键 5.监视和内存观察5.1 监视5.2 内存 1.什么是 bug bug现在一般是指在电脑系统或程序中&#xff0c;隐藏着的一些未被发现的缺陷或问题…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

C++_核心编程_多态案例二-制作饮品

#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为&#xff1a;煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例&#xff0c;提供抽象制作饮品基类&#xff0c;提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解

本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说&#xff0c;直接开始吧&#xff01; 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)

骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术&#xff0c;它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton)&#xff1a;由层级结构的骨头组成&#xff0c;类似于人体骨骼蒙皮 (Mesh Skinning)&#xff1a;将模型网格顶点绑定到骨骼上&#xff0c;使骨骼移动…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计&#xff0c;提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合&#xff1a;各模块职责清晰&#xff0c;便于独立开发…...

均衡后的SNRSINR

本文主要摘自参考文献中的前两篇&#xff0c;相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程&#xff0c;其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt​ 根发送天线&#xff0c; n r n_r nr​ 根接收天线的 MIMO 系…...

使用Spring AI和MCP协议构建图片搜索服务

目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式&#xff08;本地调用&#xff09; SSE模式&#xff08;远程调用&#xff09; 4. 注册工具提…...

深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用

文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么&#xff1f;1.1.2 感知机的工作原理 1.2 感知机的简单应用&#xff1a;基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...

永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器

一、原理介绍 传统滑模观测器采用如下结构&#xff1a; 传统SMO中LPF会带来相位延迟和幅值衰减&#xff0c;并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF)&#xff0c;可以去除高次谐波&#xff0c;并且不用相位补偿就可以获得一个误差较小的转子位…...