java中short、int、long、float、double取值范围

对于java的数据类型,既熟悉又陌生,于是整理了这篇文档。
最近的面试让我开始注意细节,细节真的很重要。

一、分析基本数据类型的特点,最大值和最小值。
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)

二、经实践证明,在代码中,能够写的位数。
1、首先是整型
      int和long只能写10个数字,short只能写5个数字,多了就会报错。

  1. int h=1234567890;
  2. long w=1234567890;
  3. short s=12345;
如果此时我在它们每个上面再加上一个数字,就会:

2、其次浮点
float的小数点后6位,double的小数点后16位。

  1. float m=123.45566778465651454545f;
  2. 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


总结:平时的积累是多么重要啊,细节,细节,细节,还是细节…………………………

PS:大呼一声细节:细节…………………………………………………………
在计算机编程语言shortintlong是表示整数类型的关键字。它们的区别在于它们所能表示的范围大小不同。 shortshort int的缩写,表示短整型。一般情况下,short占用2个字节(16位),它的取值范围较小,大约是-32,768到32,767。 int是整型的缩写,表示整数类型。在不同的编译器int的大小可以是2个字节(16位)或4个字节(32位),这取决于编译器和操作系统的要求。它的取值范围较大,大约是-2,147,483,648到2,147,483,647。 long表示长整型。在不同的编译器long的大小可以是4个字节(32位)或8个字节(64位)。它的取值范围int更大,大约是-9,223,372,036,854,775,808到9,223,372,036,854,775,807。 需要注意的是,在编程过程long类型的值需要在数字后面加上"L",以区分它们和int类型的值。例如,long num = 100000000L。 需要了解的是,并没有规定long一定要比int长,也没有规定short要比int短。根据标准规定,长整型至少和整型一样长,整型至少和短整型一样长。具体的实现方式和长度由编译器厂商决定。因此,具体的shortintlong的大小取决于所使用的编译器和操作系统。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [关于intshort intlong intlong long 的区别](https://blog.csdn.net/u012223913/article/details/51181761)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [关于 shortint ,long,和float,double 理解](https://blog.csdn.net/chujingh975868/article/details/100972058)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 20
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值