Java数据类型的类型转换

类型转换

由于Java是强类型语言,所以要进行有些运算的时候,需要用到类型转换。

常量、字符串等是可以混合运算的,char本质还是一个数字

低→→→→→→→→→→→→→→→→→→→→→→→→→→高

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

*** 运算中,不同类型的数据先转化为同一类型,然后进行运算。**

  • 强制类型转换(高到低需要强制转换)
  • 自动类型转换(低到高就不需要强制转换)

Java八大数据类型的位数

public class Demo02 {
    public static void main(String[] args) {
        int i=128;
        byte b=(byte)i;//内存溢出,byte的最大值是127,这个时候就导致内存溢出。
        //在赋值前面加上一个英文的括号()   里面加上转换类型,就是强制转换,高转低的时候才会强制转换。(类型)变量名
        /*
         强制类型转换(高到低需要强制转换)
         自动类型转换(低到高就不需要强制转换)

         注意点:
         1.不能对布尔值进行转换
         2.不能把对象类型转换为不相干的类型
         3.在把高容量转换到低容量的时候,需要强制转换
         4.转换的时候可能存在内存溢出,或者精度问题
         */

        System.out.println(i);//输出128
        System.out.println(b);//输出-128

        System.out.println("===============================");
        System.out.println((int)23.7);//输出结果23,Double类型,高转低(强制转换)
        System.out.println((int)-45.89f);//输出结果-45,float类型,高转低(强制转换)

        System.out.println("===============================");
        char c='a';
        int d=c+1;
        System.out.println(d);//输出98
        System.out.println((char) d);//输出b,a后面+1就是b,“ASCII编码表”


    }
}

public class Demo03 {
    public static void main(String[] args) {
        //操作比较大的数的时候,注意溢出问题
        //JDK7新特性,数字之间可以用下划线分割
        int money =1_000_000_000;
        int years =20;
        int total=money*years;//输出结果-1474836480,计算的时候溢出了
        long total01=money*years;//输出结果-1474836480,因为money和years默认是int类型,所以计算的时候就按照int,所以就内存溢出,转换之前就已经存在问题。

        long total02=money*((long)years);//计算之前先把一个数转换为long


        System.out.println(total02);
        //建议long用大写L,别用小写l,因为小写l容易看错成数字1,从基础养成规范。

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成。 转换规则 从存储范围小的类型到存储范围大的类型。 具体规则为: byte→short(char)→int→long→float→double 也就是说byte类型的变量可以自动转换为short类型,示例代码: byte b = 10; short sh = b; 这里在赋值时,JVM首先将b的值转换为short类型,然后再赋值给sh。 在类型转换时可以跳跃。示例代码: byte b1 = 100; int n = b1; l 注意问题 在整数之间进行类型转换时,数值不发生改变,而,特将整数类型别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。 强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型转换转换规则 从存储范围大的类型到存储范围小的类型。 具体规则为: double→float→long→int→short(char)→byte 语法格式为: (转换到的类型)需要转换的值 示例代码: double d = 3.10; int n = (int)d; 这里将double类型的变量d强制转换成int类型,然后赋值给变量n。需要说明的是小数强制转换为整数,采用的是“去1法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是3。整数强制转换为整数时取数字的低位,例如int类型的变量转换为byte类型时,则只去int类型的低8位(也就是最后一个字节)的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值