float类型转integer_【第3章:Java基础程序设计】_Java数据类型

 数据溢出

当定义一个变量的值超过该变量类型的范围时会导致数据溢出,编译都无法通过

public class TestJava{

       public static void main(String args[]){

              int n=99999999999999999999999999999999;

       }

}

818fbfbba22648641eb1755702664425.png

Integer(int最大范围)的最大值

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.print(n);

       }

}

73e69c828935694ba95982f6888df6c3.png

最大值加1是最小值,再加1就是次小值依此类推

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.println(n+1);

              System.out.println(n+2);

       }

}

609d11d477c737b9b5cf3f77b1f30ab7.png

用长整型强制转换可以解决最大值加1就是最小值的问题

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.println((long)n+2);

       }

}

f22e265edfa5b1917ac3ca34d62a1b59.png

字符的本质也是数值(ascill码),所以字符不仅仅单双引号进行定义,只要是char类型,则也可以用数值代替

public class TestJava{

       public static void main(String args[]){

              char ch1='a';

              char ch2=97;

              System.out.println(ch1);

              System.out.println(ch2);

       }

}

11c462c07d78387c038e4cd5755bfd86.png

转义字符

public class TestJava{

       public static void main(String args[]){

              char ch1='\"';

              char ch2='\\';

              System.out.println(ch1);

              System.out.println(ch2);

       }

}

687a8fa5b1196d8a34f8c20efd709e6b.png

定义浮点型数据要指定精度,否则默认精度会有默认转换的情况损失精度

这里定义浮点型3.0,那么也就是说要的是float的目的数据,而默认是double,double转换到float是会损失精度的。

public class TestJava{

       public static void main(String args[]){

              float num=3.0;

       }

}

a352bb101a88a4a653355f269d3612c1.png

指定精度后就没有问题了

public class TestJava{

       public static void main(String args[]){

              float num=3.0f;

       }

}

d794918d346e0b5d931c8ade40776b0d.png

布尔类型

public class TestJava{

       public static void main(String args[]){

              boolean flag=true;

              System.out.print(flag);

       }

}

5aa89dad9ff1816b4e57113a85b948cc.png

自动转型

这里整数除以浮点型最后的结果自动转换为浮点型了。

public class TestJava{

       public static void main(String args[]){

              int x=30;

              float y=22.19f;

              System.out.print(x/y);

       }

}

4c75a080c8f4514b62363ee7a2051c7c.png

public class TestJava{

       public static void main(String args[]){

              System.out.print(10/3.5);

       }

}

d2cabf88d35fb6164e2959b4f1e857ee.png

整型相除问题

这里相除的结果很明显损失了精度

public class TestJava{

       public static void main(String args[]){

              System.out.print(10/3);

       }

}

e7823ff2e4691cf71da549cf4f520bc5.png

用强转float可以解决该问题

public class TestJava{

       public static void main(String args[]){

              System.out.print((float)10/3);

       }

}

3db01b6d9639ce41b7dbd30321e14ae1.png

字符串与int的运算

public class TestJava{

       public static void main(String args[]){

              String str="gaojiupan";

              int x=30;

              str=str+x;

              System.out.print(str);

       }

}

上面这是正常情况,再看一个比较异常的情况

public class TestJava{

       public static void main(String args[]){

              System.out.print("1+2="+1+2);

       }

}

624721596ecc4a0b42032bee787d8751.png

这种情况是字符串直接进行追加了,没有把后面两个先计算再追加,像是下面这样就好了

public class TestJava{

       public static void main(String args[]){

              System.out.print("1+2="+(1+2));

       }

}

2c8ea851dea2317399c58a4f4e67cbb7.png

强制类型转换丢失精度

public class TestJava{

       public static void main(String args[]){

              float f=30.3f;

              int x=(int)f;

              System.out.print(x);

       }

}

ec0c88f97a71e1c2e19c81b39cfc8174.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值