欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java学习第二节第1章

程序员文章站 2022-04-03 17:14:36
...

学习目标

理解数据类型的强制转换
理解数据类型的自动转换
了解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 类 型。
Java学习第二节第1章
同样道理,当一个 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);//编译成功 
}

转换原理图解
Java学习第二节第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这个代码对吗?
运行结果如图
Java学习第二节第1章
为什么会这样呢?
上面我们已经说过,byte char short进行数学运算时会首先提升为int类型,
这里的+为数学运算符,所以进行运算时会首先提升为int型,那么提升int型后为什么会导致错误呢。
这是因为,提升的仅仅是num1和num2,左边仍然为byte类型,而右边是int类型,byte所能容纳的范围小于int类型,
导致报错。
那么如何处理呢?
将左边的byte写成int即可。

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

运行结果如下
Java学习第二节第1章
注意:布尔类型(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数据,如何让计算机可以直接识别人类文字的问题呢?就产生出了编码表的概念。
**编码表 :**就是将人类的文字和一个十进制数进行对应起来组成一张表格。
人们就规定:
Java学习第二节第1章

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

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

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

相关标签: Java基础学习笔记