char/byte/short类型的加法和类型转换问题
2015-08-13 10:43
429 查看
前天做360校招内推笔试题,其中有一道byte类型加法的问题:
byte b1=1,b2=2;
b3=b1+b2;
final byte b4=4,b5=5;
b6=b4+b5;
问b3和b5能否正常赋值?
答案应该是:b3不能正常赋值,需要类型转换,b3=(byte)(b1+b2);b6能够正常赋值。
原因分析:
在Java中,在基本类型进行算术运算的时候,会发生小字节类型向大字节类型转换的现象。对于short,byte,char 比int 字节数小的变量类型来说,运算结果会自动转换为int类型。Java编译器会在编译期或者运行期将byte和short类型的数据带符号扩展为相应的int类型数据,将boolean和char类型数据零位扩展为相应的int类型数据。因此,在处理boolean 、byte、short 和 char 类型的数组是,也会用相应的int类型的字节码指令来处理。因此,大多数对于上述类型数据的操作,实际上都是使用相应的
int 类型作为运算类型。如下:
short a=1, b=2;
short c=a+b;
System.out.println(c);
在编译时,会报出“Exception in thread "main" java.lang.Error: Unresolved compilation problem: Type mismatch: cannot convert from int to short”,可以看出可以看出a+b结果变成了int类型。
重点来了,如果是final 修饰的变量,进行运算的时候则不会出现类型转换异常。
final short a=1, b=2;
short c=a+b;
System.out.println(c);
这么操作完全OK,究其原因,对于final 修饰的基本类型的变量来说,他们之间的运算直接就被硬编码成了直接赋值语句,连中间结果都没有了,类型转换的异常也就没了。
byte b1=1,b2=2;
b3=b1+b2;
final byte b4=4,b5=5;
b6=b4+b5;
问b3和b5能否正常赋值?
答案应该是:b3不能正常赋值,需要类型转换,b3=(byte)(b1+b2);b6能够正常赋值。
原因分析:
在Java中,在基本类型进行算术运算的时候,会发生小字节类型向大字节类型转换的现象。对于short,byte,char 比int 字节数小的变量类型来说,运算结果会自动转换为int类型。Java编译器会在编译期或者运行期将byte和short类型的数据带符号扩展为相应的int类型数据,将boolean和char类型数据零位扩展为相应的int类型数据。因此,在处理boolean 、byte、short 和 char 类型的数组是,也会用相应的int类型的字节码指令来处理。因此,大多数对于上述类型数据的操作,实际上都是使用相应的
int 类型作为运算类型。如下:
short a=1, b=2;
short c=a+b;
System.out.println(c);
在编译时,会报出“Exception in thread "main" java.lang.Error: Unresolved compilation problem: Type mismatch: cannot convert from int to short”,可以看出可以看出a+b结果变成了int类型。
重点来了,如果是final 修饰的变量,进行运算的时候则不会出现类型转换异常。
final short a=1, b=2;
short c=a+b;
System.out.println(c);
这么操作完全OK,究其原因,对于final 修饰的基本类型的变量来说,他们之间的运算直接就被硬编码成了直接赋值语句,连中间结果都没有了,类型转换的异常也就没了。
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android之使用Http协议实现文件上传功能
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树