做网站的服务器带宽一般多少,怎么对一个网站做优化,郑州软件开发公司网站,创建全国文明城市调查问卷Java中#xff0c;经常可以遇到类型转换的场景#xff0c;从变量的定义到复制、数值变量的计算到方法的参数传递、基类与派生类间的造型等#xff0c;随处可见类型转换的身影。Java中的类型转换在Java编码中具有重要的作用。首先#xff0c;来了解下数据类型的基本理解经常可以遇到类型转换的场景从变量的定义到复制、数值变量的计算到方法的参数传递、基类与派生类间的造型等随处可见类型转换的身影。Java中的类型转换在Java编码中具有重要的作用。首先来了解下数据类型的基本理解数据是用来描述数据的种类包括其值和基于其值基础上的可进行的操作集合。Java中数据类型主要分为两大类基本数据类型和引用数据类型。基本数据类型共有8种分别是布尔型boolean, 字符型char和数值型byte/short/int/long/float/double。由于字符型char所表示的单个字符与Ascii码中相应整形对应因此有时也将其划分到数值型中。引用类型具体可分为数组、类和接口。因此本文中Java类型转换的总结也将分为基本数据类型和引用数据类型两个方面展开。一、基本数据类型的类型转换基本数据类型中布尔类型boolean占有一个字节由于其本身所代码的特殊含义boolean类型与其他基本类型不能进行类型的转换(既不能进行自动类型的提升也不能强制类型转换) 否则将编译出错。1.基本数据类型中数值类型的自动类型提升数值类型在内存中直接存储其本身的值对于不同的数值类型内存中会分配相应的大小去存储。如:byte类型的变量占用8位int类型变量占用32位等。相应的不同的数值类型会有与其存储空间相匹配的取值范围。具体如下所示图中依次表示了各数值类型的字节数和相应的取值范围。在Java中整数类型(byte/short/int/long)中对于未声明数据类型的整形其默认类型为int型。在浮点类型(float/double)中对于未声明数据类型的浮点型默认为double型。接下来我们看看如下一个较为经典例子1 package com.corn.testcast;234 public class TestCast {56 public static void main(String[] args) {7 byte a 1000; //编译出错 Type mismatch: cannot convert from int to byte8 float b 1.5; //编译出错 Type mismatch: cannot convert from double to float9 byte c 3; //编译正确10 }1112 }是不是有点奇怪按照上面的思路去理解将一个int型的1000赋给一个byte型的变量a编译出错提示cannot convert from int to byte是对的1.5默认是一个double型将一个double类型的值赋给一个float类型编译出错这也是对的。但是最后一句将一个int型的3赋给一个byte型的变量c居然编译正确这是为什么呢原因在于jvm在编译过程中对于默认为int类型的数值时当赋给一个比int型数值范围小的数值类型变量(在此统一称为数值类型kk可以是byte/char/short类型)会进行判断如果此int型数值超过数值类型k那么会直接编译出错。因为你将一个超过了范围的数值赋给类型为k的变量k装不下嘛你有没有进行强制类型转换当然报错了。但是如果此int型数值尚在数值类型k范围内jvm会自定进行一次隐式类型转换将此int型数值转换成类型k。如图中的虚线箭头。这一点有点特别需要稍微注意下。在其他情况下当将一个数值范围小的类型赋给一个数值范围大的数值型变量jvm在编译过程中俊将此数值的类型进行了自动提升。在数值类型的自动类型提升过程中数值精度至少不应该降低(整型保持不变float-double精度将变高)。1 package com.corn.testcast;23 public class TestCast {45 public static void main(String[] args) {6 long a 10000000000; //编译出错: The literal 10000000000 of type int is out of range7 long b 10000000000L; //编译正确8 int c 1000;9 long d c;10 float e 1.5F;11 double f e;12 }1314 }如上定义long类型的a变量时将编译出错原因在于10000000000默认是int类型同时int类型的数值范围是-2^31 ~ 2^31-1因此10000000000已经超过此范围内的最大值故而其自身已经编译出错更谈不上赋值给long型变量a了。此时若想正确赋值改变10000000000自身默认的类型即可直接改成10000000000L即可将其自身类型定义为long型。此时再赋值编译正确。将值为1000的int型变量c赋值给long型变量d按照上文所述此时直接发生了自动类型提升 编译正确。同理将e赋给f编译正确。接下来还有一个地方需要注意的是char型其本身是unsigned型同时具有两个字节其数值范围是0 ~ 2^16-1因为这直接导致byte型不能自动类型提升到charchar和short直接也不会发生自动类型提升(因为负数的问题)同时byte当然可以直接提升到short型。2.基本数据类型中的数值类型强制转换当我们需要将数值范围较大的数值类型赋给数值范围较小的数值类型变量时由于此时可能会丢失精度(1讲到的从int到k型的隐式转换除外)因此需要人为进行转换。我们称之为强制类型转换。首先我们看一下如下的例子1 package com.corn.testcast;23 public class TestCast {45 public static void main(String[] args) {6 byte p 3; //编译正确:int到byte编译过程中发生隐式类型转换7 int a 3;8 byte b a; //编译出错cannot convert from int to byte9 byte c (byte) a; //编译正确10 float d (float) 4.0;11 }1213 }byte p 3编译正确在1中已经进行了解释。接下来将一个值为3的int型变量a赋值给byte型变量b发生编译错误。这两种写法之间有什么区别呢区别在于前者3是直接量编译期间可以直接进行判定后者a为一变量需要到运行期间才能确定也就是说编译期间为以防万一当然不可能编译通过了。此时需要进行强制类型转换。强制类型转换所带来的结果是可能会丢失精度如果此数值尚在范围较小的类型数值范围内对于整型变量精度不变但如果超出范围较小的类型数值范围内很可能出现一些意外情况。如下经典例子1 package com.corn.testcast;23 public class TestCast {45 public static void main(String[] args) {6 int a 233;7 byte b (byte) a;8 System.out.println(b: b); //输出-239 }1011 }为什么结果是-23需要从最根本的二进制存储考虑。233的二进制表示为24位0 11101001byte型只有8位于是从高位开始舍弃截断后剩下11101001由于二进制最高位1表示负数0表示正数其相应的负数为-23。3.进行数学运算时的数据类型自动提升与可能需要的强制类型转换如下代码1 package com.corn.testcast;23 public class TestCast {45 public static void main(String[] args) {6 byte a 3 5; //编译正常 编译成 35直接变为87 int b 3, c 5;8 byte d b c; //编译错误cannot convert from int to byte910 byte e 10, f 11;11 byte g e f; //编译错误 直接将10和11类型提升为了int12 byte h (byte) (e f); //编译正确13 }1415 }当进行数学运算时数据类型会自动发生提升到运算符左右之较大者以此类推。当将最后的运算结果赋值给指定的数值类型时可能需要进行强制类型转换。二、引用类型的类型转换/造型本部分内容将在后续时间在本文中补上。