【JavaSE基础】-----------运算符大全(代码详细,通俗易懂)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 今天为了大家讲解Java基础中比较重要的知识点——运算符。

1.什么是运算符?


       如果是学过C语言的东西,应该大部分的运算符都知道,但是Java部分的运算符和C还是有一定的区别。如果是直接从Java开始接触编程的同学,那么我就会告诉你,运算符就类型数学中的加减乘除这种符号,当然编程中远不止这些。它类似一种“功能”符号,用来操作我们的数据类型。往下看就明白了。


1.算术运算


符号

作用 说明
+ 加分运算
- 减法运算
* 乘法运算
/

除法运算
% 取余 求余运算

       加减乘除运算大家都不会陌生,取余运算可能还有点见的少。但是这里我们这里要注意浮点数类型的加减乘除运算,也就是小数的加减运算。如果对基本数据类型还不太了解,需要去多了解一下,下面我也会进行演示。


public static void main(String[] args) {
        //整数运算
        int a=100;
        int b=24;
        System.out.println(a+b);//124
        System.out.println(a-b);//76
        System.out.println(a*b);//2400
        System.out.println(a/b);//4
        System.out.println(a%b);//4
        //浮点数运算(小数)
        double c=5.5;
        double d=0.2;
        System.out.println(c+d);//5.7
        System.out.println(c-d);//5.3
        System.out.println(c*d);//1.1
        System.out.println(c/d);//27.5
        System.out.println(c%d);//0.0999999999999997
    }

解析:对于整数的运算,加减乘除我们就不需要多说,就和我们数学里是一样的。余数其实也是和数学中的一样,因为100处于24是除不尽的,还剩4,所以余数就为4,所以如果我们10%3就会得到1,因为10除于3余数是1。这里一定有同学有疑问,那为什么100/24会等于4,明明是除不尽,这里就要讲讲编程语言的特性,先看下图


image.png


图中三个除法运算都是无法除尽的,红色的就是数字就是我们的答案,在代码中,如果两个整数相处我们无法除尽,我们只要他的商即可,小数部分直接舍去,因为我们整数相除只能得到一个整数,所以小数部分会被舍去,有的同学就会问那我一定要得到小数呢?那也不是没有办法的


int a=100;
        int b=24;
        System.out.println(a/b);//4
        int c=100;
        double d=24;
        System.out.println(c/d);//4.166666666666667
        int e=100;
        int f=24;
        System.out.println((double) e/f);//4.166666666666667

解析:第一种情况就是正常情况,拿来和下面对比,如果两个整数相除无法除尽就会舍去小数部分。想要得到小数的第一种方法就是将其中一个整形变量改为浮点数类型的变量,就像第二种情况,一个整数类型与一个小数相除答案就会得到一个小数。整数类型不能写成小数,但是可没说小数不能写成整数,所以对于d赋值24不要有太大疑问。如果有同学硬要两个整数相除得到小数咋办,我们jvm也会办法硬对这种杠精,我们在运算操作前加一个(double),强行将int的答案转为double类型,当然这种方法有一定风险,对于有些转换会产生精度损失,所以推荐大家用第一种方法。


2. 赋值运算符


符号

作用 说明
= 赋值 a=10,将整数值10赋值给变量a
+= 加后赋值 a+=b,将a+b的结果赋值给a
-= 减后赋值 a-=b,将a-b的结果赋值给a
*= 乘后赋值 a*=b,将a*b的结果赋值给a
/= 除后赋值 a/=b,将a/b的结果赋值给a
%= 取余后赋值 a%=b,将a%b的结果赋值给a 

ps:注意强制类型转换问题


解析:在运算符的使用中,赋值运算符的优先级是最低的,所以我们其实a+=b就等于a=a+b。运算后的值都重新赋值给前面一个变量,如果想给b那就写成b+=a。后面的都类似就不过多写,可以自己在编译器上试试。


3.自增运算符(重点)


符号

作用 说明
++ 自增1 a++,将变量a的值增加1
-- 自减1 a--,将变量a的值减1

这样看上去好像很简单很好理解,不就加1减1嘛,但是先上个代码给大家看看。


public static void main(String[] args) {
        int a=10;
        int b=9;
        System.out.println(a++);//10
        System.out.println(++a);//12
        System.out.println(b--);//9
        System.out.println(--b);//7
        int c=(a++)-(--b);
        System.out.println(c);;//6
    }

解析:自增自减运算符是初学者最容易犯错的地方,虽然这个看上去非常简单,但是逻辑性是非常强的。首先要记住一句话,++放前面优先级最高,++放后面优先级最低。首先第一句输出语句我们要输出a++的值,因为++在后优先级很低,所以我们先输出了a为10的结果,然后它才会自增1变成11,这时接下来要输出++a的结果,因为++在前的优先级很高,所以这时应该先自增再输出,所以a=11再加1a就变成了12。减法同理,先输出了再减,所以看上去输出了9,实际输出完以后b就变成了8,这时再输出--b,就得先减b再输出所以为7。这时看最后的输出语句,因为是a++,优先级非常低,所以最后a才会自增,a暂时还是12,后面是--b,优先级非常高,所以马上就自减变成了6,所以是12-6等于6,最后c为6,这时运算结束以后a才自增变成13,不行的可以复制代码再后面接着打印a的值。这里同时要记住++放后面的优先级比赋值运算符=优先级还要低,如图


public static void main(String[] args) {
        int a=10;
        int c=a++;
        System.out.println(c);//10
    }


4.关系运算符


符号

说明
== a==b,判断a和b的值是否相等,成立为true,否则为false
!= a!=b,判断a和b的值是否不等,成立为true,否则为false
> a>b,判断a是否大于b,成立为true,否则为false
>= a>=b,判断a是否大于等于b,成立为true,否则为false
< a<b,判断a是否小于b,成立为true,否则为false
<= a<=b,判断a是否小于等于b,成立为true,否则为false

ps:1.关系运算符的结果只有两种true和false,这是基本数据类型boolean的两种值


2.千万不要把==写成=,=是赋值而==才是比较是否相等!!(虽然这是每个人必犯的错但还是要提醒一下。。。)          


5.逻辑运算符    

符号

作用 说明
& 逻辑与 a&b,a和b都为true,结果为true,否则false   
| 逻辑或 a|b,a和b都是false,结构为false,否则为true
^ 逻辑异或 a^b,a和b的值相同为false,否则为true
逻辑非 !a的结构和a相反
&& 短语与 作用同&,但是有短路效果
|| 短路或 作用同|,但是有短路效果

PS:1.关于数值范围的描述的表达,比如1<a<10


       2.逻辑与&和短路与&&的区别(短路效果)(同理推|与||的区别)


                       逻辑与&,无论左边真假,右边都判断


                       逻辑与&&,当左边为假,右边根本不判断


相关文章
最好、最坏、均摊,这都是啥?
最好、最坏、均摊,这都是啥?
116 0
最好、最坏、均摊,这都是啥?
|
3天前
|
人工智能 自然语言处理 Shell
深度评测 | 仅用3分钟,百炼调用满血版 Deepseek-r1 API,百万Token免费用,简直不要太爽。
仅用3分钟,百炼调用满血版Deepseek-r1 API,享受百万免费Token。阿里云提供零门槛、快速部署的解决方案,支持云控制台和Cloud Shell两种方式,操作简便。Deepseek-r1满血版在推理能力上表现出色,尤其擅长数学、代码和自然语言处理任务,使用过程中无卡顿,体验丝滑。结合Chatbox工具,用户可轻松掌控模型,提升工作效率。阿里云大模型服务平台百炼不仅速度快,还确保数据安全,值得信赖。
157353 24
深度评测 | 仅用3分钟,百炼调用满血版 Deepseek-r1 API,百万Token免费用,简直不要太爽。
|
5天前
|
人工智能 API 网络安全
用DeepSeek,就在阿里云!四种方式助您快速使用 DeepSeek-R1 满血版!更有内部实战指导!
DeepSeek自发布以来,凭借卓越的技术性能和开源策略迅速吸引了全球关注。DeepSeek-R1作为系列中的佼佼者,在多个基准测试中超越现有顶尖模型,展现了强大的推理能力。然而,由于其爆火及受到黑客攻击,官网使用受限,影响用户体验。为解决这一问题,阿里云提供了多种解决方案。
16973 37
|
13天前
|
机器学习/深度学习 人工智能 自然语言处理
PAI Model Gallery 支持云上一键部署 DeepSeek-V3、DeepSeek-R1 系列模型
DeepSeek 系列模型以其卓越性能在全球范围内备受瞩目,多次评测中表现优异,性能接近甚至超越国际顶尖闭源模型(如OpenAI的GPT-4、Claude-3.5-Sonnet等)。企业用户和开发者可使用 PAI 平台一键部署 DeepSeek 系列模型,实现 DeepSeek 系列模型与现有业务的高效融合。
|
5天前
|
并行计算 PyTorch 算法框架/工具
本地部署DeepSeek模型
要在本地部署DeepSeek模型,需准备Linux(推荐Ubuntu 20.04+)或兼容的Windows/macOS环境,配备NVIDIA GPU(建议RTX 3060+)。安装Python 3.8+、PyTorch/TensorFlow等依赖,并通过官方渠道下载模型文件。配置模型后,编写推理脚本进行测试,可选使用FastAPI服务化部署或Docker容器化。注意资源监控和许可协议。
1310 8
|
13天前
|
人工智能 搜索推荐 Docker
手把手教你使用 Ollama 和 LobeChat 快速本地部署 DeepSeek R1 模型,创建个性化 AI 助手
DeepSeek R1 + LobeChat + Ollama:快速本地部署模型,创建个性化 AI 助手
3416 117
手把手教你使用 Ollama 和 LobeChat 快速本地部署 DeepSeek R1 模型,创建个性化 AI 助手
|
8天前
|
人工智能 自然语言处理 API
DeepSeek全尺寸模型上线阿里云百炼!
阿里云百炼平台近日上线了DeepSeek-V3、DeepSeek-R1及其蒸馏版本等六款全尺寸AI模型,参数量达671B,提供高达100万免费tokens。这些模型在数学、代码、自然语言推理等任务上表现出色,支持灵活调用和经济高效的解决方案,助力开发者和企业加速创新与数字化转型。示例代码展示了如何通过API使用DeepSeek-R1模型进行推理,用户可轻松获取思考过程和最终答案。
|
5天前
|
人工智能 自然语言处理 程序员
如何在通义灵码里用上DeepSeek-V3 和 DeepSeek-R1 满血版671B模型?
除了 AI 程序员的重磅上线外,近期通义灵码能力再升级全新上线模型选择功能,目前已经支持 Qwen2.5、DeepSeek-V3 和 R1系列模型,用户可以在 VSCode 和 JetBrains 里搜索并下载最新通义灵码插件,在输入框里选择模型,即可轻松切换模型。
934 14
|
12天前
|
API 开发工具 Python
阿里云PAI部署DeepSeek及调用
本文介绍如何在阿里云PAI EAS上部署DeepSeek模型,涵盖7B模型的部署、SDK和API调用。7B模型只需一张A10显卡,部署时间约10分钟。文章详细展示了模型信息查看、在线调试及通过OpenAI SDK和Python Requests进行调用的步骤,并附有测试结果和参考文档链接。
1938 9
阿里云PAI部署DeepSeek及调用
|
9天前
|
人工智能 数据可视化 Linux
【保姆级教程】3步搞定DeepSeek本地部署
DeepSeek在2025年春节期间突然爆火出圈。在目前DeepSeek的网站中,极不稳定,总是服务器繁忙,这时候本地部署就可以有效规避问题。本文以最浅显易懂的方式带读者一起完成DeepSeek-r1大模型的本地部署。

热门文章

最新文章