Java基本数据类型short、int、long、float、double取值范围long和int 的区别:
64位系统中,long是8字节,int是4字节
long允许的数字范围要更⼴
⼀、分析基本数据类型的特点,最⼤值和最⼩值。
1、
基本类型:int ⼆进制位数:32
包装类:java.lang.Integer
最⼩值:Integer.MIN_VALUE= -2147483648 (-2的31次⽅)
最⼤值:Integer.MAX_VALUE= 2147483647 (2的31次⽅-1)
2、
基本类型:short ⼆进制位数:16
包装类:java.lang.Short
最⼩值:Short.MIN_VALUE=-32768 (-2的15此⽅)
最⼤值:Short.MAX_VALUE=32767 (2的15次⽅-1)
3、
基本类型:long ⼆进制位数:64
包装类:java.lang.Long
最⼩值:Long.MIN_VALUE=-9223372036854775808 (-2的63次⽅)
最⼤值:Long.MAX_VALUE=9223372036854775807 (2的63次⽅-1)
4、
基本类型:float ⼆进制位数:32
包装类:java.lang.Float
最⼩值:Float.MIN_VALUE=1.4E-45 (2的-149次⽅)
最⼤值:Float.MAX_VALUE=3.4028235E38 (2的128次⽅-1)
5、
基本类型:double ⼆进制位数:64
包装类:java.lang.Double
最⼩值:Double.MIN_VALUE=4.9E-324 (2的-1074次⽅)
最⼤值:Double.MAX_VALUE=1.7976931348623157E308 (2的1024次⽅-1)
下⾯的值都是正负。。。我说的是位数的最⼤值和最⼩值
float
最⼤值:3.4028235E38 = 340282350000000000000000000000000000000
最⼩值:1.4E-45 = 0.0000000000000000000000000000000000000000000014 double
最⼤值:1.7976931348623157E308这个值太⼤了就是
1.7976931348623157这个数⼩数点往右移308位
最⼩值:4.9E-324
这个数就是4.9除以10的324次⽅。。。。
Float 最⼩值 :1.4E-45。
最⼤值:3.4028235E38。
Double最⼩值: 1.7976931348623157E308。
最⼤值:4.9E-324 。
⼆、经实践证明,在代码中,能够写的位数。
1、⾸先是整型
int和long只能写10个数字,short只能写5个数字,多了就会报错。
int h=1234567890;
long w=1234567890;
浮点型变量floatshort s=12345;
如果此时我在它们每个上⾯再加上⼀个数字,就会:
2、其次浮点
float的⼩数点后6位,double的⼩数点后16位。
float m=123.45566778465651454545f;
double n=3.1234567890123456789;
然后打印出来的结果是这样的:
三、⼩插曲 -----int和Integer的区别
1.从定义上来看
int 是基本类型,直接存数值(类似的还有float、double、String、char)
Integer是对象,⽤⼀个引⽤指向这个对象(类似的有Float、Double、String)
2.从复杂度来看,Java 中的数据类型分为基本数据类型和复杂数据类型
int 是前者;Integer 是后者(也就是⼀个类)
3.初始化的⽅式不同
int i =1;
Integer i= new Integer(1);//integer 是⼀个类
int 是基本数据类型(⾯向过程留下的痕迹,不过是对java的有益补充);Integer 是⼀个类,是int的扩展,定义了很多的转换⽅法
注意:类似的还有:float Float;double Double;String等,其中String较为特殊,基本类型和复杂类似关键字相同。
例如,当需要往ArrayList,HashMap中放东西时,像int,double这种内建类型是放不进去的,因为容器都是装 object的,这是就需要这些内建类型的外覆类了。Java中每种内建类型都有相应的外覆类。
Java中int和Integer关系是⽐较微妙的。关系如下:
int是基本的数据类型;
Integer是int的封装类;
int和Integer都可以表⽰某⼀个数值;
int和Integer不能够互⽤,因为他们两种不同的数据类型;
举例说明
ArrayList A_List=new ArrayList();
int n=40;
Integer In=new Integer(n);
A_List.add(n);//error
A_List.add(In);//ok
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论