Java学习第二节第1章

学习目标

理解数据类型的强制转换
理解数据类型的自动转换
了解ASCII编码表
理解int类型和char类型的运算原理
理解运算符++ --的运算方式
理解+符号在字符串中的作用
理解比较运算符
理解逻辑运算符
掌握三元运算符的格式和计算结果
了解方法的概念
掌握无返回值无参数方法的定义格式
了解方法定义的注意事项

第一章 数据类型转换

Java程序中要求参与的计算的数据,必须要保证数据类型的一致性,如果数据类型不一致将发生类型的转换。

1.1 自动转换

一个 int 类型变量和一个 byte 类型变量进行加法运算, 结果会是什么数据类型?

int i = 1;
byte b = 2;

运算结果,变量的类型将是 int 类型,这就是出现了数据类型的自动类型转换现象。
**自动转换:**将 取值范围小的类型 自动提升为 取值范围大的类型 。

public static void main(String[] args) {
 int i = 1; 
 byte b = 2; 
 // byte x = b + i; 
 // 报错 
 //int类型和byte类型运算,结果是int类型 
 int j = b + i; 
 System.out.println(j); 
 }

转换原理图解

byte 类型内存占有1个字节,在和 int 类型运算时会提升为 int 类型 ,自动补充3个字节,因此计算后的结果还是 int 类 型。
在这里插入图片描述
同样道理,当一个 int 类型变量和一个 double 变量运算时, int 类型将会自动提升为 double 类型进行运算。

public static void main(String[] args) { 
int i = 1; 
double d = 2.5; 
//int类型和double类型运算,结果是double类型 
//int类型会提升为double类型 
double e = d+i; 
System.out.println(e); 
}

转换规则

范围小的类型向范围大的类型提升, byte、short、char 运算时直接提升为 int 。

byteshortchar‐‐>int‐‐>long‐‐>float‐‐>double

1.2 强制转换

将 1.5 赋值到 int 类型变量会发生什么?产生编译失败,肯定无法赋值

int i = 1.5; // 错误

double 类型内存8个字节, int 类型内存4个字节。
1.5 是 double 类型,取值范围大于 int 。
可以理解为 double 是8 升的水壶, int 是4升的水壶,不能把大水壶中的水直接放进小水壶去。
想要赋值成功,只有通过强制类型转换,将 double 类型强制转换成 int 类型才能赋值。

强制类型转换:
将取值范围大的类型 强制转换成 取值范围小的类型 。 比较而言,自动转换是Java自动执行的,而强制转换需要我们自己手动执行。

转换格式:

数据类型 变量名 = (数据类型)被转数据值;

将 1.5 赋值到 int 类型,代码修改为:

// double类型数据强制转成int类型,直接去掉小数点。 
int i = (int)1.5;

同样道理,当一个 short 类型与 1 相加,我们知道会类型提升,但是还想给结果赋值给short类型变量,就需要强制转换。

public static void main(String[] args) {

//short类型变量,内存中2个字节 
short s = 1; 
/*出现编译失败 s和1做运算的时候,1是int类型,s会被提升为int类型 
s+1后的结果是int类型,将结果在赋值会short类型时发生错误 short内存2个字节,
int类型4个字节 必须将int强制转成short才能完成赋值 */
s = s + 1//编译失败 
s = (short)(s+1);//编译成功 
}

转换原理图解
在这里插入图片描述
强烈注意
浮点转成整数,直接取消小数点,可能造成数据损失精度。
int 强制转成 short 砍掉2个字节,可能造成数据丢失。

// 定义s为short范围内最大值 
short s = 32767; 
// 运算后,强制转换,砍掉2个字节后会出现不确定的结果 
s = (short)(s + 10);

强制转换并不建议使用 ,因为可能会出现精度损失和数据溢出。

数据溢出(整数):
比如我将60000000000赋值给长整型,但是长整型的数据范围无法容纳那么多,所以显示出来的数字必定不是它,这就出现了数据溢出。
同时,为什么将int 转换成long可以呢,因为long本身就能容纳比int更大的数字,就像水桶装水一样,long这个水桶比int这个水桶更大一点,那么int这个水桶能装下的long水桶必然也能装下。
精度损失(小数):
比如我将3.5赋值给int ,3.5本来为浮点型数字,赋值给int之后只能保存整型数字3。这就出现了精度损失。
注意:这里并不是四舍五入,是只保留整型!所有的小数都会被舍去。

byte
short
char
这三种类型都可以发生数学运算,例如+ -运算。
这三种类型在发生数学运算是都会被首先提升为int型然后进行计算

Eg:

byte num1=40byte num2=50byte result=num1+num2;

byte这个代码对吗?
运行结果如图
在这里插入图片描述
为什么会这样呢?
上面我们已经说过,byte char short进行数学运算时会首先提升为int类型,
这里的+为数学运算符,所以进行运算时会首先提升为int型,那么提升int型后为什么会导致错误呢。
这是因为,提升的仅仅是num1和num2,左边仍然为byte类型,而右边是int类型,byte所能容纳的范围小于int类型,
导致报错。
那么如何处理呢?
将左边的byte写成int即可。

代码如下
byte num1=40byte num2=50int result=num1+num2;

运行结果如下
在这里插入图片描述
注意:布尔类型(boolean)无法强制转换!!

1.3 ASCII编码表

public static void main(String[] args) { 
//字符类型变量 char c = 'a'; int i = 1; 
//字符类型和int类型计算 
System.out.println(c+i);
//输出结果是98 }

在计算机的内部都是二进制的0、1数据,如何让计算机可以直接识别人类文字的问题呢?就产生出了编码表的概念。
**编码表 :**就是将人类的文字和一个十进制数进行对应起来组成一张表格。
人们就规定:
在这里插入图片描述

char zifu1='A';
		System.out.println(zifu1+5);`

A的ASCII值为65
输出结果即为70
理解:因为有+运算,所以char类型先提升为int类型,然后参与计算。所以得出结果为70

之前我们输入单个中文也能输出文字,但是ASCII上并没有对应的中文,那么为什么能够输出呢?
解释:
ASCII全程是美国信息交换标准代码,除此之外我们还有Unicode码表,即万国码,它包含了除了ASCII之外的更多字符
即使是表情符号也能在Unicode中找到对应的编码,中国的中在Unicode中对应数字20013,所以当然能输出啦。

猜你喜欢

转载自blog.csdn.net/aa1832090510/article/details/107424676
今日推荐