Java之基本数据类型>..<

1.关于整数型

(仔细阅读代码里面的注释!!!有帮助,涉及类型转换

package Test6;
/*
 * 1、java语言当中的“整数型字面值”被默认当做int类型来处理。要让这个“整数型字面值”
 * 被当做long类型来处理的话,需要在“整数型字面值”后面添加l/L,建议使用大写的L
 * 
 * 2.Java语言当中的整数型字面值有三种表示方式:
 * 第一种方式:十进制【是一种缺省默认的方式】常用
 * 第二种方式:八进制【在编写八进制整数型字面值的时候需要以0开始】
 * 第三种方式:十六进制【在编写十六进制整数型字面值的时候需要以0x开始】
 */

public class DataTypeTest04 {

	public static void main(String[] args) {
		int a=10;
		int b=010;//整数型字面值以0开头的,后面那一串数字就是八进制形式
		int c=0x10;//整数型字面值以0x开头的,后面那一串数字就是十六进制形式
		System.out.println(a);
		System.out.println(b);
		System.out.println(c);
		System.out.println(a+b+c);
		
		/*
		 * 123这个整数型字面值是int类型
		 * i变量声明的时候也是int类型
		 * int类型的123赋值给int类型的变量i,不存在类型转换
		 */
		int i=123;
		System.out.println(i);
		
		
		 /* 456整数型字面值被当做int类型,占用4个字节
		 * x变量在声明的时候是long类型,占用8个字节
		 * int类型的字面值456赋值给long类型的变量x,存在类型转换
		 * int类型转换成long类型
		 * int类型是小容量
		 * long类型是大容量
		 * 小容量可以自动转换成大容量,称为自动类型转换机制。
		 */
		long x=456;
		System.out.println(x);
		
		//2147483647字面值是int类型,占用4个字节
		//y是long类型,占用8个字节,自动类型转换
		long y=2147483647;
		System.out.println(y);
		/*
		 * 编译错误:过大的整数:2147483648
		 * 2147483648被当做int 类型4个字节处理,但是这个字面值超出int类型范围
		 * long z=2147483648;
		 * 解决错误
		 * 2147483648字面值一上来就当做long类型来处理,在字面值后面添加L
		 * 2147483648L是8个字节的long类型
		 * z是long类型,以下程序不存在类型转换
		 */
		long z=2147483648L;
		System.out.println(z);
	}

}

 细节讲解:【做好笔记!!!】

       /*100L是long类型字面值
         * x是long类型变量
         * 不存在类型转换,直接赋值
         */

        long x=100L;


        /*x变量是long类型,8个字节
         * y变量是int类型,4个字节
         * 以下程序可以编译通过嘛?
         * 编译报错,大容量不能直接赋值给小容量
         *  int y=x;
         *  --大容量转换成小容量,需要进行强制类型转换
         *  强制类型转换需要加“强制类型转换符”
         *  加上强制类型转换符之后编译通过,但是运行阶段可能损失精度。
         *  所以强制类型转换谨慎使用,因为损失精度之后可能损失很严重

        * eg. int y=(int)x;

        * 强转原理:
         * 原始数据:00000000 00000000 00000000 00000000
         *          00000000 00000000 00000000 01100100
         * 强转之后的数据:00000000 00000000 00000000 01100100
         * 将左边的二进制砍掉【所有的数据强转的时候都是这样完成的】
         */

        int y=(int)x;
        System.out.println(y);
        
        /* 原始数据:00000000 00000000 00000000 00000000
         *          10000000 00000000 00000000 00000000
         * 强转之后的数据:10000000 00000000 00000000 00000000
         * 10000000 00000000 00000000 00000000目前存在计算机内部,计算机存储数据都
         * 是采用补码的形式存储所以10000000 00000000 00000000 00000000现在是一个补码形式
         * 将以上的补码转换到原码就是最终的结果
         */ 

          long k=2147483648L;
         int e=(int)k;
         System.out.println(e);//损失精度严重,结果是负数【-2147483648】
         
         /*
          * 分析以下程序是否可以编译通过?
          * 依据目前所学内容,以下程序是无法编译通过
          * 理由:50是int类型字面值,b是byte类型的变量,显然是大容量int转换小容量byte
          * 大容量转换为小容量是需要添加强制类型转换符的,以下程序没有添加强转符号,所以编译报错。
          * 但是,在实际编译的时候,以下代码通过了,这说明:在java语言当中,当一个整数型字面值
          * 没有超过byte类型范围的话,该字面值可以直接赋值给byte类型的变量。
          */

         byte b=50;
         byte c=127;
         /*
          * 编译报错,128这个int类型的字面值已经超过了byte类型的取值范围,不能直接赋值给byte类型的变量
          * byte b1=128;
          */

         /*
          * 纠正错误,需要使用强制类型转换符
          * 但是一定会损失精度
          * 原始数据:00000000 00000000 00000000 10000000
          * 强转之后:10000000【这是存储在计算机内部的,这是一个补码,它的原码是什么?】

          */
         byte b1=(byte)128;
         System.out.println(b1);//损失精度严重,结果是负数【-128】
    }

 完整代码分析:

package Test6;

public class DataTypeTest05 {

	public static void main(String[] args) {
		/*100L是long类型字面值
		 * x是long类型变量
		 * 不存在类型转换,直接赋值
		 */
		long x=100L;
		/*x变量是long类型,8个字节
		 * y变量是int类型,4个字节
		 * 以下程序可以编译通过嘛?
		 * 编译报错,大容量不能直接赋值给小容量
		 *  int y=x;
		 *  --大容量转换成小容量,需要进行强制类型转换
		 *  强制类型转换需要加“强制类型转换符”
		 *  加上强制类型转换符之后编译通过,但是运行阶段可能损失精度。
		 *  所以强制类型转换谨慎使用,因为损失精度之后可能损失很严重
		 * eg. int y=(int)x;
		 * 
		 * 强转原理:
		 * 原始数据:00000000 00000000 00000000 00000000
		 *          00000000 00000000 00000000 01100100
		 * 强转之后的数据:00000000 00000000 00000000 01100100
		 * 将左边的二进制砍掉【所有的数据强转的时候都是这样完成的】
		 */
		int y=(int)x;
		System.out.println(y);
		
		/* 原始数据:00000000 00000000 00000000 00000000
		 *          10000000 00000000 00000000 00000000
		 * 强转之后的数据:10000000 00000000 00000000 00000000
		 * 10000000 00000000 00000000 00000000目前存在计算机内部,计算机存储数据都
		 * 是采用补码的形式存储所以10000000 00000000 00000000 00000000现在是一个补码形式
		 * 将以上的补码转换到原码就是最终的结果
		 */
         long k=2147483648L;
         int e=(int)k;
         System.out.println(e);//损失精度严重,结果是负数【-2147483648】
         
         /*
          * 分析以下程序是否可以编译通过?
          * 依据目前所学内容,以下程序是无法编译通过
          * 理由:50是int类型字面值,b是byte类型的变量,显然是大容量int转换小容量byte
          * 大容量转换为小容量是需要添加强制类型转换符的,以下程序没有添加强转符号,所以编译报错。
          * 但是,在实际编译的时候,以下代码通过了,这说明:在java语言当中,当一个整数型字面值
          * 没有超过byte类型范围的话,该字面值可以直接赋值给byte类型的变量。
          */
         byte b=50;
         byte c=127;
         /*
          * 编译报错,128这个int类型的字面值已经超过了byte类型的取值范围,不能直接赋值给byte类型的变量
          * byte b1=128;
          */
         /*
          * 纠正错误,需要使用强制类型转换符
          * 但是一定会损失精度
          * 原始数据:00000000 00000000 00000000 10000000
          * 强转之后:10000000【这是存储在计算机内部的,这是一个补码,它的原码是什么?】
          */
         byte b1=(byte)128;
         System.out.println(b1);//损失精度严重,结果是负数【-128】
	}

}

         short s=32767; //通过
        // short s1=32768;  编译报错
         
         /*
          * 65535是int类型,4个字节
          * cc是char类型,2个字节
          * 按照以前所学知识来说,以下程序是编译报错的。
          */

         char cc=65535;
         //cc=65536;编译报错
         /*
          * byte x=()128;
          * 当一个整数字面值没有超过byte,short,char的取值范围,
          * 这个字面值可以直接赋值给byte,short,char类型的变量。这个机制SUM
          * 允许了,目的是为了方便程序员的编程。
          */

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值