Java语言中:在数据类型的讲解中补充的几个小问题
=============================================================================
1:在定义Long或者Float类型变量的时候,要加L或者f。
整数默认是int类型,浮点数默认是double。
byte,short在定义的时候,他们接收的其实是一个int类型的值。
这个是自己做了一个数据检测的,如果不再它们的范围内,就报错。
例如:
byte a = 50; // 其实50是int类型的。
short b = 100; // 其实100是int类型的。
-----------------------------------------------------------------------------
2:byte值的问题:即默认是有符号的。
byte b1 = 127; // 127
byte b2 = (byte)128; // -128
byte b3 = (byte)129; // -127
byte b4 = (byte)130; // -126
......
byte b4 = (byte)255; // -1
byte b4 = (byte)256; // 0
byte b4 = (byte)257; // +1
---------------------------------------
byte b1 = -128; // -128
byte b2 = (byte)-129; // +127
byte b3 = (byte)-130; // +126
byte b4 = (byte)-131; // +125
......
byte b4 = (byte)-255; // +1
byte b4 = (byte)-256; // 0
byte b4 = (byte)-257; // -1
---------------------------------------
所以有个规律是:在任何范围内,如果给个较大的值,在截取的时候,当比最大值还大的时候,又会绕回去从最小的开始。
所以有个规律是:在任何范围内,如果给个较小的值,在截取的时候,当比最小值还小的时候,又会绕回去从最大的开始。
---------------------------------------
byte的范围:-128 ~ 127
128: 1000 0000
-128:1000 0000 (可以这样认为:这里的1既是符号位,也是数值位。)
其实1000 0000表示-0。
其实实际上byte的范围是 -127,-126,-125,...,-1,-0,+0,+1,...,+125,+126,+127
但是呢我们一般认为的是0不分正负的,所以为了区别以及为了超过范围数还能绕回去,叫做数据的回环!,就上面那样做了。
-----------------------------------------------------------------------------
3:数据类型转换之默认转换:
byte,short,char --> int --> long --> float --> double
默认转换
但是呢?
long: 8个字节
float:4个字节
为什么long会在前面呢?
---------------------------------------
原因是:
A:它们底层的存储结构不同。所有的整数是按照1010...去存储的,但浮点数是按照科学计数法的表示的,所以存储的有效数字位以及次幂。
B:这样就导致了float表示的数据范围比long的范围要远远大。
long:-2^63 ~ 2^63-1
float:3.4*10^38 > 2*10^38 > 2*8^38 = 2*2^3^38 = 2*2^114 >> 2^63-1
---------------------------------------
Java浮点类型常量有两种表示形式:
十进制数形式, 如:3.14 314.0
科学记数法形式, 如:3.14e2 3.14*10^2
Java各整数类型有固定的表数范围和字段长度,其不受具体操作系统的影响,以保证Java程序的可移植性。
所谓的有效数字:具体地说,是指在分析工作中实际能够测量到的数字。所谓能够测量到指的是包括最后一位估计的不确定的数字。
例如:对于一个近似数,从左边第一个不是0的数字起,到精确到的位数止,所有的数字都叫做这个数的有效数字。
-----------------------------------------------------------------------------
4:面试题:Java语言中的字符char可以存储一个中文汉字吗?为什么呢?
可以。因为java语言中的字符char占用两个字节。
Java语言采用的是Unicode编码。(Unicode是全球语言统一编码)
=============================================================================
【转载文章务必保留出处和署名,谢谢!】