学习目标
理解数据类型的强制转换
理解数据类型的自动转换
了解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 。
byte、short、char‐‐>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=40;
byte num2=50;
byte result=num1+num2;
byte这个代码对吗?
运行结果如图
为什么会这样呢?
上面我们已经说过,byte char short进行数学运算时会首先提升为int类型,
这里的+为数学运算符,所以进行运算时会首先提升为int型,那么提升int型后为什么会导致错误呢。
这是因为,提升的仅仅是num1和num2,左边仍然为byte类型,而右边是int类型,byte所能容纳的范围小于int类型,
导致报错。
那么如何处理呢?
将左边的byte写成int即可。
byte num1=40;
byte num2=50;
int 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,所以当然能输出啦。