万字Java基础原理知识大总结(中)

简介: Java诞生于1995年,原属于SUN公司,2009年4月20日,美国数据软件巨头甲骨文公司(Oracle)宣布以74亿美元收购SUN公司。Java是最受欢迎的开发语言,已经火了20年,并将继续引领着IT的编程语言。Java的LOGO是一杯热气腾腾的咖啡,真的是令人回味无穷。

六、表达式


表达式(expression),是由数字、运算符、括号、常量、变量等以能求得结果的组合


1.JPG


七、数据类型的转换


在8大基本数据类型中,boolean不属于数值类型,所以不参与转换,其他类型的转换规则如下图。一般的,byte、short、char三种类型相互之间一般不参与转换操作,按照转换方式,有两种(注意:boolean类型不参与类型转换):


  1. 自动类型转换:范围小的数据类型直接转换成范围大的数据类型,小->大
  2. 强制类型转换:范围大的数据类型强制转换成范围小的数据类型,大->小


2.JPG


7.1、自动类型转换与提升


7.1.1、自动类型转换


自动类型转换,也称为“隐式类型转换,就是把范围小的数据类型直接转换成范围大的数据类型


转换规则:byte、short、char—>int—>long—>float—>double

注意事项:byte、short、char相互之间不转换,他们参与运算首先转换为int类型

语法格式:范围大的数据类型 变量 = 范围小的数据类型值


public class TypeConvertDemo1{
  public static void main(String[] args) {
    //把int类型变量转为long类型
    long longNumber = 17;//整数默认为int类型
    //把long类型转换为float类型
    float f1 = longNumber;
    //把float类型转换为double类型
    double d = f1;
    //定义两个int类型的变量
    int a1 = 2;
    int b1 = 3;
    int c1 = a1 + b1;
    //定义一个byte类型,一个int类型
    byte b2 = 2;
    int c2 = 3;
    System.out.println(b2 + c2);
    //byte、short、char类型参与运算时把自己提升为int类型
    //byte d1 = b2 + c2;//编译报错
    int d3 = b2 + c2;//编译通过
  }
}
复制代码


7.1.2、自动类型提升


当一个算术表达式中,包含多个基本数据类型的常量或变量(boolean除外)时,整个算术表达式的结果类型将出现自动提升,其规则是:


  • 所有的byte、short、char类型被自动提升到int类型,再参与运算
  • 整个表达式的最终结果类型,被提升到表达式中类型最高的类型


System.out.println('a' + 1);//98
byte b = 22;
b = b + 11;//编译出错,此时结果类型应该是int
double d1 = 123 + 1.1F + 3.14 + 99L ;
复制代码

结论:算数表达式结果的类型就是其中范围最大的数据类型。


7.2、强制类型转换


强制类型转换,也称为“显式类型转换”,就是把范围大的数据类型强制转换成范围小的数据类型


# 语法格式:
# 范围小的数据类型  变量 = (范围小的数据类型)范围大的数据类型值;
复制代码


注意:一般情况下不建议使用强转,因为强转有可能损失精度


public class TypeConvertDemo2{
  public static void main(String[] args) {
    int a = 2;
    byte b = 3;
    //自动类型转换
    int c = a + b;
    //强制类型转换
    byte d = (byte) (a + b);
    //把double转换为int类型
    int i = (int)3.14;
    System.out.println(i);//3
  }
}
复制代码


八、运算符


对常量和变量进行操作的符号称为运算符

常见的运算符分为:算术运算符、赋值运算符、比较运算符、逻辑运算符、三元运算符


8.1、算数运算符


运算符 运算规则1 示例 结果
+ 正号 +3 3
+ 52+3 5
+ 拼接字符串 "中"+"国" “中国”
- 符号 int a = 3
-a
-3
- 3-1 2
* 2*3 6
/ 5/2 2
% 取模 5%2 1
++ 自增 int a = 1
a++(++a)
2
-- 自减 int b =2
b--(--b)
1


8.2、自增和自减


自增:++,递增操作符,使变量值增加1,有前置和后置之分,只能操作变量

自减:-- ,递减操作符,使变量值减去1,有前置和后置之分,只能操作变量

以++为例:


a++和++a结果都是让a的值自增1,如果只是需要自增的话,使用哪一种都可以

但是他们俩有唯一的区别:

  1. 前置(++a):  表示对a加1之后的结果进行运算,先加后用
  2. 后置(a++):表示对a变量加1之前的值(原始值)进行运算,先用后加


public class ArithmeticOperatorsDemo2{
  public static void main(String[] args) {
    int a1 = 5;
    int b1 = ++ a1;
    System.out.println("a1=" + a1 + ",b1=" + b1);//a1=6,b1=6
    int a2 = 5;
    int b2 = a2 ++;
    System.out.println("a2=" + a2 + ",b2=" + b2);//a2=6,b2=5
  }
}
复制代码

比较底层的解释

++a表示取a的地址,增加它的内容,然后把值放在寄存器中 a++表示取a的地址,把它的值装入寄存器,然后增加内存中的a的值


8.3、赋值运算符


运算符 运算规则 示例 结果
== 是否相等于 4==3 false
!= 是否不等于 !4=3 true
< 小于 4<3 false
> 大于 4>3 true
<= 小于等于 4<=3 false
>= 大于等于 4>=3 true


8.4、三元运算符


三元运算符,表示有三个元素参与的表达式,所以又称为三目运算符,其语义表示if-else(如果什么情况就做什么,否则做什么)

语法格式:数据类型 变量 = boolean表达式 ?  结果A :结果B

表达的意思,boolean表达式结果:


  • 为true,则三元运算符的结果是结果A
  • 为false,则三元运算符的结果是结果B


注意:

  1. 三元运算符必须定义变量接受运算的结果,否则报错
  2. 三元运算符结果的类型由结果A和结果B来决定的,结果A和结果B的类型是相同的


8.5、逻辑运算符


逻辑运算符用于连接两个boolean表达式,结果也是boolean类型的


运算符 运算规则 示范 结果
& false & true false
| false | true true
^ 异或 true ^ false true
! !true false
&& 短路与 false && false false
|| 短路或 false || false true


规律:

  • 非:取反,!true则false,!false则true
  • 与:有false则false
  • 或:有true则true
  • 异或:^ 相同则false,不同则true


8.5.1、&和&&( | 和 | |)的区别


& :&左边表达式无论真假,&右边表达式都进行运算

&& :如果&&左边表达式为真,&&右边表达式参与运算,否则&&右边表达式不参与运算,故称短路与| 和 || 的区别同理,||,左边为真,右边不参与运算


public class LogicalOperatorDemo2 {
  public static void main(String[] args) {
    System.out.println(false & 1 / 0 == 1);//报错,说明右边执行了
    System.out.println(false && 1 / 0 == 1);//不报错,说明右边没有执行
    System.out.println(true | 1 / 0 == 1);//报错,说明右边执行了
    System.out.println(true | 1 / 0 == 1);//不报错,说明右边没有执行
  }
}
复制代码



相关文章
|
2天前
|
Java 调度
Java并发编程:深入理解线程池的原理与实践
【4月更文挑战第6天】本文将深入探讨Java并发编程中的重要概念——线程池。我们将从线程池的基本原理入手,逐步解析其工作过程,以及如何在实际开发中合理使用线程池以提高程序性能。同时,我们还将关注线程池的一些高级特性,如自定义线程工厂、拒绝策略等,以帮助读者更好地掌握线程池的使用技巧。
|
2天前
|
Java
软件工程设计原理迪米特法则原则优缺点及JAVA代码举例
【4月更文挑战第8天】迪米特法则,也称为最少知识原则,是软件工程中一个旨在减少软件实体之间耦合关系的设计原则。它建议一个对象应该对其他对象有尽可能少的了解,并且只与直接的朋友通信。
45 10
|
1天前
|
Java 数据库连接 Spring
K8S+Docker理论与实践深度集成java面试jvm原理
K8S+Docker理论与实践深度集成java面试jvm原理
|
2天前
|
算法 安全 Java
深入探索Java中的并发编程:CAS机制的原理与应用
总之,CAS机制是一种用于并发编程的原子操作,它通过比较内存中的值和预期值来实现多线程下的数据同步和互斥,从而提供了高效的并发控制。它在Java中被广泛应用于实现线程安全的数据结构和算法。
24 0
|
2天前
|
存储 监控 安全
JVM工作原理与实战(十六):运行时数据区-Java虚拟机栈
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了运行时数据区、Java虚拟机栈等内容。
12 0
|
2天前
|
搜索推荐 Java Shell
8大Java排序方法(由简入繁),有代码详解和原理指导
8大Java排序方法(由简入繁),有代码详解和原理指导
33 0
|
2天前
|
存储 安全 Java
【Java EE】CAS原理和实现以及JUC中常见的类的使用
【Java EE】CAS原理和实现以及JUC中常见的类的使用
|
2天前
|
编解码 JavaScript 前端开发
【专栏】介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例
【4月更文挑战第29天】本文介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例。Base64编码将24位二进制数据转换为32位可打印字符,用“=”作填充。文中展示了各语言的编码解码代码,帮助开发者理解并应用于实际项目。
|
2天前
|
监控 搜索推荐 算法
Java排序:原理、实现与应用
【4月更文挑战第28天】本文探讨了Java中的排序算法,包括原理和实现。Java利用Comparator接口进行元素比较,通过Arrays和Collections类的sort方法对数组和列表进行排序。示例展示了使用这些方法的基本代码。此外,还讨论了冒泡排序算法和自定义排序场景,以适应不同需求。理解这些排序机制有助于提升程序效率。
13 1
|
2天前
|
设计模式 消息中间件 Java
Java 设计模式:探索发布-订阅模式的原理与应用
【4月更文挑战第27天】发布-订阅模式是一种消息传递范式,被广泛用于构建松散耦合的系统。在 Java 中,这种模式允许多个对象监听和响应感兴趣的事件。
39 2