1.数据类型强制转换
/**
* 思考题1:请问下面这个有没有问题
* double d=12.345;
* float f=d;
*
* 思考题2:看看下面两个定义有没有区别?
* float f1=(float)12.345;
* float f2=12.345f;
* f1其实是通过一个double类型转换过来的
* 而f2本身就是一个float类型
*/
public class DataTypeDemo5 {
public static void main(String[] args) {
//把double赋值给float,加了强制类型转换
double d=12.345;
float f=(float)d;
}
}
面试题:
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么?
b=b1+b2;是有问题的。
因为变量相加,会首先看类型问题,最终把结果赋值的时候也会考虑类型问题。
常量相加,首先做加法,然后看结果是否在赋值的数据类型范围内,如果不是,才报错。
public class DataTypeDemo6 {
public static void main(String[] args) {
byte b1=3,b2=4,b;
//b=b1+b2;//这个是类型提升,所以有问题,b1+b2为int类型。
b=3+4;//常量,先把结果计算出来,然后看是否在byte的范围内,如果在就不报错
}
}
byte b=130;有没有问题?如果我想让赋值正确,可以怎么做?结果是多少呢?
byte bb=(byte) 130;结果分析过程:
我们要想知道结果是什么,就应该知道是如何进行计算的。
而我们又知道计算机中数据的运算都是补码进行的。
而要得到补码,首先要计算机出数据的二进制。
A:获取130这个数据的二进制。
00000000 00000000 00000000 100000010
这是130的原码,也是反码,还是补码
B:做截取操作,截成byte类型的了
10000010
这个结果是补码。
C:已知补码求原码。
符号位 数值位
补码: 1 0000010
反码: 1 0000001
原码: 1 1111110
结果为-126。
练习2:byte bc=300;有没有问题?如果我想让赋值正确,可以怎么做?结果是多少呢?
byte bc=(byte) 300;结果分析过程:
A:首先将300(int类型为4个字节32位)转换为二进制
00000000 00000000 00000001 00101100
这是300的原码,也是反码,还是补码
B:做截取byte类型(1个字节)的操作
00101100
C:符号位为0,结果是补码,反码和原码相同
所以最后结果为44。
2.字符串参与运算
看程序写结果
字符串数据和其他数据做+,结果是字符串类型。
这里的+不是加法运算,而是字符串连接符。
public class DataTypeDemo9 {
public static void main(String[] args) {
System.out.println("hello"+'a'+1);//helloa1
System.out.println('a'+1+"hello");//98hello
System.out.println("5+5="+5+5);//5+5=55
System.out.println(5+5+"=5+5");//10=5+5
}
}