码迷,mamicode.com
首页 > 编程语言 > 详细

java类型转换详解(自动转换和强制转换)

时间:2018-03-09 01:47:13      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:取值   java类型   static   short   从表   相加   print   system   优化   

自动转换

class Hello
{
	public static void main(String[] args)
	{
		//自动转换
		int a = 5;
		byte b = 6;
		int c = a + b;
		System.out.println(c);
	}
}

 a是int类型,b是byte类型 当二者进行加法运算时(根据同类型相加结果还是同类型) 由于int的范围比byte的取值范围大这个时候jvm会自动将b转换成int类型

强制转换

//强制转换
		int a = (int)8.8;

 强制转换就是将前面加上要转换的类型就可以了。

下面来看比较特殊的

class Hello
{
    public static void main(String[] args)
    {
        byte b = 3;//正确
        int x = 3;//正确
        b = x;//错误
        
    }
}

 

 上面代码在编译的时候会报错 常量3的类型为int   int类型可以赋值给byte的变量    但是b=x这个时候就不行了呢   因为根据常量优化机制  这种方式只针对 常量  不针对变量 也就是说大范围的不能赋值给小范围  除非用强制转换类型

在看下面的也遵循上面的原则

class Hello
{
	public static void main(String[] args)
	{
		byte b1=3,b2=4,b;//正确
		b = b1 + b2;//错误   因为b1  b2这个时候是变量(常量优化机制只针对常量不针对变量)
		b = 3 + 4;//正确
		
	}
}

 

 在看一个例子

class Hello
{
    public static void main(String[] args)
    {
        
        short s = 1;
        s = s + 1;//错误

        和
        
        short s = 1;
        s+=1;//正确
    }
}

 

 上面的代码从表面上看是没什么区别的 为什么第二种写法就正确了呢?

第一种算的时候  会将s自动转换为int类型在进行加法运算(低精度转高精度)  然后得出的结果是int类型  在赋值给short类型 这样是不合适的(高精度不能赋值给低精度类型)所以会报错 正确的写法如下面代码

class Hello
{
	public static void main(String[] args)
	{
		
		short s = 1;
		s = (short)(s + 1);

		System.out.println(s);
	}
}

 那第二种为什么是可行的呢?

因为+=、-+、*=、/=  这些运算符比较特殊  本身就具有强制类型转换的作用。

 

java类型转换详解(自动转换和强制转换)

标签:取值   java类型   static   short   从表   相加   print   system   优化   

原文地址:https://www.cnblogs.com/nianzhilian/p/8531710.html

(0)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!