java数据存储

一、数据类型

【特点】Java一共有八种基本数据类型,因为java和Python不一样,它是一种强类型语言,每一种变量都有一种类型。

整型

byte           short           int         long

浮点型fioat           double
布尔型boolean
字符型

char

Java有三种引用数据类型,引用数据类型建立在基本数据类型的基础上,包括数组、类String和接口。

整型和浮点型的存储需求、取值范围
类型字节长度(bit)取值范围
int4 -2 147 483 648 ~ 2 147 483 647
short2-32 768 ~ 32 767
long8

-9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807

byte1 -128 ~ 127
float4大约±3.402 823 47E+38F(6~7位有效数字)
double8大约±1.797 693 134 862 315 70E+308(15位有效数字)

字节(B)是计算机信息技术用于计量存储容量和传输容量的一种计量单位,1个字节等于8位二进制。既1Byte(字节)= 8bit(位)

char类型的值要用单引号括起来,如:’A‘。

boolean类型只有两个值:false和true,用来判断逻辑条件。

二、为什么byte类型127+1是(-128)

先用程序实现一下

public class Demo {
    public static void main(String[] args) {
		byte a = 127;
		byte b = (byte)(a+1);
		System.out.println(b);
}
}

输出结果是-128

byte类型的字节长度是8字节,其中第一个数字是符号位,代表数据的正负,正数的话就是0,负数的话就是1,2的七次方是128,考虑正负的话可以表示的数据数目就是128*2=256,这显然是没有地方表示0,这就是我给出的为什么没有128的第一个思考。

接下来以这个问题为引讨论精度问题。

三、计算机存储数据形式——补码

为了讨论方便,讨论所用的数据类型皆是byte类型。

45-45

原码

00101101

10101101

反码

00101101

11010010

补码

00101101

11010011

原码就是原来的数据的意思

正数的原码和反码相同,负数的反码等于原码的符号位不变,其余各位按位取反0换成1,1换成0

正数的原码反码和补码都形同,负数的补码等于在其反码基础上末尾+1

四、反码的存在意义

 因为计算机只有加法没有减法,在做减法运算的时候,可以认为是加上一个负数,这样可以减少计算机电路的复杂度。使用原码进行减法运算会出现问题,例如计算1-1,因为计算机有加法没有减法,所以计算机自动换算成1+(-1)

1-1=1+(-1)

=[00000001]原+[10000001]原

=[10000010]原

=-2 (符号位也参与运算)

与实际结果不符

-------------------------------------------------------------------------------------

1-1=1+(-1)

=[00000001]原+[10000001]原

=[00000001]反+[11111110]反

=[11111111]反

=[10000000]原

=-0

通过反码计算的结果是11111111在计算一次反就成原码了,得出的结果是正确的,但是有一个问题是 00000000可以代表+0 10000000可以代表-0,其实是一样的,用2个编码实在是浪费。于是出现了补码解决0的符号以及两个编码的问题

--------------------------------------------------------------------------------------------

1-1=1+(-1)

=[00000001]原+[10000001]原

=[00000001]补+[11111111]补

=[00000000]补

=[00000000]原

这样0用[0000 0000]表示, 而以前出现问题的-0则不存在了.

------------------------------------------------------------------------------------------------

总结:反码是为了解决减法运算,补码是为了解决反码产生的+-0的问题

这时候再回答一下之前的问题“为什么byte类型127+1是(-128)

先看下图

使用补码, 不仅仅修复了0的符号以及存在两个编码的问题, 而且还能够多表示一个最低数. 这就是为什么8位二进制, 使用原码或反码表示的范围为[-127, +127], 而使用补码表示的范围为[-128, 127]。

因为机器使用补码, 所以对于编程中常用到的32位int类型, 可以表示范围是: [-2^31, 2^31-1] 因为第一位表示的是符号位.而使用补码表示时又可以多保存一个最小值。

五、浮点类型的精度丢失

关于定点数和浮点数的知识,这里不再进行文字描述,不过笔者可以推荐一个视频,笔者觉得讲的很棒,传送链接:nullhttp://hdu.fanya.chaoxing.com/portal额 有6个收藏还是不错的 我继续https://www.bilibili.com/video/BV1mx411M7Ts?share_source=copy_web

对于之前学过也可以尝试看这张图回忆一下

 

1.浮点类型在计算机中的存储

https://note.youdao.com/yws/public/resource/207ca381aa54e46209311f68565650c3/xmlnote/C9292F7F0E214B5982723425FD862A95/60956

float存储需求是4字节(32位), 其中1位最高位是符号位,中间8位表示阶位,后32位表示值

double存储需求是8字节(64为),其中1位最高位是符号位,中间11位表示阶位,后52位表示值

拓展:float是32位的,double是64位的,所以double能存储更高的精度。

2.浮点类型的精度丢失

2.1例子

public class SimpleTest {
    public static void main(String[] args) {
    	System.out.println(1.2 - 1);
    }
}

 output:0.19999999999999996

这显然与我们预期的结果0.2不一致

 接下来,我们将十进制的0.2转换为二进制表示,十进制小数转化为二进制数, 算法是乘以2直到没有了小数为止。0.2表示成二进制数

                     0.2*2=0.4   取整数部分 0

                     0.4*2=0.8   取整数部分 0

                     0.8*2=1.6   取整数部分 1

                     0.6*2=1.2   取整数部分 1

                     0.2*2=0.4   取整数部分 0

                       .........     

                     0.2二进制表示为(从上往下): 00110011......

注意:上面的计算过程循环了,也就是说*2永远不可能消灭小数部分,这样算法将无限下去。很显然,小数的二进制表示有时是不可能精确的 。其实道理很简单,十进制系统中能不能准确表示出1/3呢?同样二进制系统也无法准确表示1/10。这也就解释了为什么浮点型减法出现了"减不尽"的精度丢失问题。

这里出现了我们的位数不够表示我们整个数值的情况,这就叫做精度丢失。

2.2解决精度丢失

public static void main(String[] args) {
		   BigDecimal b1 = new BigDecimal(Float.toString(1.2f));
		   BigDecimal b2 = new BigDecimal(Float.toString(1));
		   float s = b1.subtract(b2).floatValue(); 
		   System.out.println("s----" + s);
}

 

六、char类型

1.字符类型实际上是一个16位无符号整数,这个数对应字符的编码

2.java字符类型采用Unicode字符集编码。Unicode是世界通用的定字长字符集,所用字符都是16位

 

	public static void main(String[] args) {
		char c1 = '中';
		char c2 = '\u4e2d';
		System.out.println(c1);
		System.out.println(c2);
	}

注释:’4e2d‘为’中‘所对应的16位Unicode编码

3.任何一个字符都可以转化为一个整数,整数的范围是0-65535

	public static void main(String[] args) {
		int  a = '中';
		System.out.println(a);
	}

4.可以查看某个数对应着那个字符

public static void main(String[] args) {
		char c = 69;
		System.out.println(c);

output

E

七、转义字符

对于不方便输出的字符可以采用转义字符表示:

例如:

public static void main(String[] args) {
		int num = 100;
		String json = "{"+"\"count\":"+num+"}";// /斜杠 \反斜杠
  		String dataString = "[{\"id\":\"1\" ,\"name\":\"张三\"},{\"id\":\"2\" ,\"name\":\"李四\"},{\"id\":\"3\" ,\"name\":\"王五\"}]";
		System.out.println(json);
}

output

{"count":100}

----------------------------------------------------------------------------------------------------------------

转义字符 含义

\n 表示回车

\r 表示换行符

\\ 表示反斜杠( \ )

\' 表示单引号( ' )

\" 表示双引号( " )

---------------------------------------------------------------------------------------------------------------------

八、boolean类型

boolean(布尔)类型有两个值:flase和true,用来判断逻辑条件。数值型和boolean之间不能直接转化。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值