java数据类型转换陷阱包括列表陷阱

java 数据类型转换的陷阱

本文通过时间数值的处理来研究一下数据类型的自动转换。我们知道:System.currentTimeMillis();返回的是long类型的数值。当计算时间相加的时候,如果不注意数据类型的自动转换,则很容易出现问题,如下所示:

Date expiration = new Date(System.currentTimeMillis() + 1000 * 60 * 60 * 24 * 365 * 5);

上面例子本意是求5年后的过期时间,而实际输出的结果却比当前时间还早的时间值。究其原因是java数值计算过程中发生的溢出。为什么会出现溢出呢?java不是存在数据类型自动转换吗?转换规则如下所示:

低————————————–>高

byte,short,char->int->long->float->double

在运算中,不同类型的数据先转化为同一类型,然后进行运算。虽然java中存在数据类型自动转换,但是需要注意的是:各运算符是有优先级的,乘法的运算优先级要高于加法,因此,java会执行完乘法运算后再执行加法运行。而执行乘法运算时,所有的操作数都是int型,因此没有触发自动类型转换,运算的结果自然是int型的,所以导致1000 * 60 * 60 * 24 * 365 * 5在计算过程中发生溢出。知道了原因就好办了,可以在乘法运算时进行一次强制类型转换:

Date expiration = new Date(System.currentTimeMillis() + 1000L * 60 * 60 * 24 * 365 * 5);

从而可以获得正确的过期时间。

java避开基本数据类型转换列表陷阱

在开发过程中经常会使用Arrays和Collections这两个工具类在数组和列表之间进行转换,使用起来非常方便,但有时候会不小心陷入陷阱里面,看代码

public static void main(String[] args) {
     int[] data = http://www.cppcns.com/ruanjian/java/{1,2,3,4,5};
     List list = Arrays.asList(data);
     System.out.println(list.size());
 }

答案为5 是不是?但是运行代码看看然而 结果为 1;是不是很意外?很吃惊?

别急,慢慢回答你的疑惑,先看下 Arrays.asList 的底层实现代码,

 public static <T> List<T> asList(T... a) {
  return new ArrayList<>(a);
 }

通过看底层源码,我们知道这个功能是通过泛型实现的,我们也知道java8个基本数据类型是不能泛型化的,在上面的代码中 Arrays.asList 将数组当做一个整体进行处理了,

为了解决这个问题我们将 代码稍稍改下就好,将基本数据类型变为包装类型就解决了

public static void main(String[] args) {
     Integer[] data = http://www.cppcns.com/ruanjian/java/{1,2,3,4,5};
     List list = Arrays.asList(data);
     System.out.println(list.size());
   }

java基本数据类型转换与陷阱

强类型语言

Java 语言是一种强类型的语言。强类型的语言有以下几个要求:

第一、变量或常量必须有类型,而且只能在声明以后才能使用。
第二、赋值时类型必须一致:值的类型必须和变量或常量的类型完全一致。
第三、运算时类型必须一致:参与运算的数据类型必须一致才能运算。

基本数据类型转换

(1) boolean类型不参与转换 (2)隐式转换 A:从小到大 B:byte,short,char – int – long – float – double C:byte,short,char之间不相互转换,直接转成int类型参与运算。 (3)强制转换 A:从大到小:可能会有精度的损失,一般不建议这样使用。 B:格式: 目标数据类型 变量名 = (目标数据类型) (被转换的数据); 注意:byte和short型都没有常量形式。他们都是接收一个不超过他们取值范围的int型常量(隐式转换);如果这个int常量超过了他们的取值范围必须使用强制转换。

思考题和面试题

A:下面两种方式有区别吗?

float f1 = 12.345f;
float f2 = (float)12.345;

B:下面的程序有问题吗,如果有,在哪里呢?

byte b1 = 3;//ok
byte b2 = 4;//ok
b1 = b1 + 1;//error
b1 += 1; //ok,扩展的赋值运算符隐含了一个强制类型转换。
b1=(byte)(b1+1);//ok,同上
byte b3 = b1 + b2;//编译失败,因为是变量
byte b4 = 3 + 4;//ok,因为是常量

C:下面的操作结果是什么呢?

byte b = (byte)130;

D:字符参与运算

System.out.println('a');//a

java数据类型转换陷阱包括列表陷阱

扫一扫手机访问