Java数据类型转换

Java程序在赋值或运算时,小精度类型会自动转换为大精度类型,如int到double。浮点数运算可能存在陷阱,比如2.7与8.1/3的比较,应通过比较差值的绝对值来判断。数据类型按精度排序:char 摘要由CSDN通过智能技术生成

基本数据类型转换(Java程序在进行赋值或者运算的时候,精度小的类型自动转换为精度大的数据类型,这个就是自动类型转换(AutoConvert))

(浮点数的使用陷阱:2.7和8.1/3的比较,当我们对运算结果是小数的进行判断的时候应该小心,正确的处理方式是得到两个数的差值的绝对值后,再在某个精度范围内判断。)

double num11 = 2.7;
double nnum12 = 8.1/3;//得到的结果不是2.7,而是2,699999999999
if(Math.abs(num11 = num12)<0.0000001){
    System.out.println("差值非常小,认为相等...");
}

数据类型按照,精度(容量)大小排序为:

char、int、long、float、double

byte、short、int、long、float、double

int a = 'c';//可以自动转化
double d = 80;//80是int类型,中间虽然有间隔,但仍然可以自动转换成double

有多种类型的数据混合运算的时候,系统会首先将所有的数据转换成容量最大的那种数据类型,然后再进行计算。当我们把精度(容量)大的数据类型赋值给精度(容量)小的数据类型时,就会报错,反之就会进行自动类型转换。

int n1 = 10;//对的
int n2 = 1.1;//错误,double到int过不去
double num = .123;//等价0.123 

byte b11 = 10;
//对的,因为10 是在byte类型范围是在-128到127之间,当把一个具体的数赋给byte时,应该先判断该数是否在byte范围内,
//如果是就不会报错,但是下面这样就不行
int b22 = 1;
byte b33 = n2;//范围超过了

float d1 = n1 +1.1
//因为Java的浮点类型默认是double型(声明float型常量,后面需要加上f或F,
//通常情况下是要使用double型,因为它比float更精确),而double型又是最高的数据类型,转换成float肯定会错
//要想转换成对的情况
float d2 = n1 + 1.1f
//或者
double d3 = n1 + 1.1
//或者
double d4 = n1 + 1.1f

(byte 、short) 和char之间不会相互自动转换。(即不能把一个byte转成一个char,也不能把一个short去转成一个char,反之也不行。)

但byte 、short、char三者可以计算,在计算时首先会转成int类型。

Boolean不参与转换。

自动提升原则:表达式结果的类型自动提升为操作数中最大的类型。

强制类型转换:(自动转换的逆过程,将最大容量的数据类型转换成容量小的数据类型,使用时要加上强制转换符(),但可能造成精度降低或溢出,格外要小心。)

强制转换符号只针对最近的操作数有效,往往会使用小括号提升优先级

int i = (int)1.9;//此时的i就变成了1(精度有损失)
int j = 100;
byte b1 = (byte)j;//这个时候输出一个负值,表示已经溢出了

将基本数据类型转成String类型

(将基本数据类型的值+“”即可)

int n1 = 100;
float f1 = 1,1f;
double d1 = 4.5;
boolen b1 = true;
//将n1转成String类型的字符串
String s1 = n1 +"";
//其他的同理

将String类型转成基本数据类型

(通过基本数据类型的包装类调用paseXX方法即可)(parse单词就是转换,解析 的意思)

String s1 = "123";
int num1 = Integer.parseInt(s1);
//其他类型的包装类转换同理,如Double  Float  long  Byte  Boolean  Short

  • 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、付费专栏及课程。

余额充值