JAVA基本数据类型转换

转自:http://my.oschina.net/lovedreamland/blog/13000

boolean类型不可以转换成其他的数据类型;

● 整形、字符型、浮点型的数据在混合运算中相互转换,转换时遵循如下规则:

    ■ 容量小的类型自动转换成容量大的数据类型;数据类型按容量大小排序如下:         byte,short,charàintàlongàfloatàdouble

        要注意的是byte,short,char之间不会相互转换,他们三者在计算时首先转换 为int类型。byte的取值范围是-128~127

n  容量大的数据类型转换为容量小的数据类型时,要加上强制转换符,但可能造成精

度降低或者溢出;使用时候要格外注意。

n  有多种类型的数据混合运算时,系统首先自动地将所有类型转换成容量最大的那个

数据类型,然后再进行计算。

● 实数常量(如:1.2)默认为double。(故:float f = 22.2;是错误的)

● 整数类型(如:123)默认为int。

● 可以直接把一个int类型的数赋值给一个byte,short,char类型的变量,但是不能超过其对应的范围(直接截取最后的一个字节)。

● 要理解容量大的数强制转换成容量小的数的实质是截取后面的字节(如:int类型转换成double类型的时候,是直接取int类型中4个字节的最后一个字节),但是double转换成float类型,由于double中存在小数点的情况,因此直接加强制转换时转换不过来的(infinity)。

● long类型8个字节,int类型4个字节,short类型2个字节,byte类型1个字节。

Float类型4个字节,double类型8个字节。

l  典型问题:

(1)  double d = 1e200;//打印显示Infinity;

(2)  float f = 11.1//错误;默认为double类型,应该修改为float f = 11.1f;

(3)public class TestDataKind {

            public static void main(String[] args) {

               byte b = 44;

               char c = 'b';

               short s = 1024;

               int i = 40000;

               long l = 12463l;

               float f = 35.67f;

               double d = 3.1234d;

       /*

        * (f * b)时,b自动提升为float类型 (l*f)时,l自动提升为float类型 (i/c)

*时,c自动提升为int类型

        * (d*s)时,s自动提升为double类型 再相加时,中间结果都变为了double类型。

        * 这里result只能声明为double类型,result声明为其他类型会出错,除非进行

*强制类型转换

        */

               double result = (f * b) + (l * f) + (i / c) - (d * s);

               System.out.print((f * b) + " + " + (l * f) + " + " + (i /

c) + " - " + (d * s));

               System.out.println(" = " + result);

            }

}

(4) byte b1 = (byte)128;

byte b2 =(byte)-129;

System.out.println(b1);

System.out.println(b2);

    打印结果:-128和127

    分析:byte只有八位,只能表示-128—127;计算机中负数的存储方式是补码。对负数的绝对值的二进制值取反,再加一,即为负数的二进制码。如:-1的绝对值1的二进制码为00000001,取反得到11111110,再加一为11111111。-128的绝对值128的二进制码为10000000,取反得到01111111,再加一为10000000,正好是Byte的最大表示范围。而-129的绝对值129的二进制码为10000001,取反后得01111110,加一后得01111111,最后结果就是127


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值