摘要:数据怎么会有类型数据难道不就是或者组成的字节码吗没错,在计算机中,只能存储或者,也就是说从存储的角度来看,根本没有类型这种东西,它们确实不过就是或者组成的字节码。数据之所以有类型,那取决于人的看法,而不却决于数据本身,数据本身是没有类型的。
什么是数据类型
简单理解就是数据的类型。
what?数据怎么会有类型?数据难道不就是0或者1组成的字节码吗?
没错,在计算机中,只能存储0或者1,也就是说从存储的角度来看,根本没有类型这种东西,它们确实不过就是0或者1组成的字节码。
那为什么还会有数据类型?
因为,类型是相当于编程者(人)来说的,人把数据分成不同的类型,方便理解,方便计算。
比如:
int a = 0x61; char b = 0x61; float c = 0x61; double d = 0x61; System.out.println(a+" "+b+" "+c+" "+d);
输出结果是:97 a 97.0 97.0。
四个不同类型的变量,给与相同的字节码0x61,但是输出竟然不同!why?
因为编程者(人)给0x61这个16进制数赋予了类型,或者说给它赋予了含义。
为什么要赋予类型(含义)?是为了让0或1的字节码能够表示更具体的东西,或是说把它映射为人能理解的东西。
不设置类型,也可以对0x61这个数进行各种运算,但是。。。what is the meaning?
没有意义,对于一个整数进行加减乘除具有现实意义,对于一个字符小写变大写具有现实意义,可是对于一个二进制数的操作却是没有意义的。人不能理解的事情是没有意义的。
那么什么是数据类型?
就是人看待数据的方式,人理解数据的方式,人规定数据的方式,这就是数据类型。
数据之所以有类型,那取决于人的看法,而不却决于数据本身,数据本身是没有类型的。
为什么上面程序的输出不同?
因为输出就是把数据变成人想要的格式显示给人看。
计算机怎么知道人想要什么格式?通过数据类型!
当0x61被规定为int型时计算机就知道应该显示十进制数6*16+1 = 97。
当0x61被规定为char型时计算机就知道应该显示十进制数6*16+1 = 97代表的ascii码所对应的字符"a"。
虽然它们在计算机中都是同一个字节码0x61,但是因为人规定了类型,所以计算机才返回不同的结果。
从编解码的角度来看
编码是信息从一种形式或格式转换为另一种形式的过程,解码,是编码的逆过程。
具体来讲编码就是,把人理解的东西转换为计算机理解的东西,而解码则是把计算机理解的东西转换为人理解的东西。
计算机理解什么?只理解0和1,人呢?almost everything。
它们之间转换的桥梁是什么?就是数据类型!人只有规定了数据的类型,规定人所理解的事情如何转换为计算机理解的字节码,才能完成这种转换!
举例:
对于97这个数字,人可以理解它为一个十进制数,但是计算机只能理解0或者1,那么如何让计算机理解?
给97编码。how?如果用二进制编码,则把97变成了1100001这个数。这样计算机就理解(能存储和计算)了,那么人怎么理解1100001这个二进制码呢?计算机在显示的时候把1100001这个数进行二进制解码,解码成97,人就理解了,而之所以能转换,是因为规定了二进制编码解码的规则,并且规定了它是个整数。而对于"a"这个字符,人理解为它是一个小写字母a,如何让计算机理解?还是编码?编什么码?编ASCII码,"a"的ASCII码是1100001,这样计算机又理解(能存储和计算)了,计算机如何让人理解1100001,解码!ASCII解码,就变成了"a",这样人就又理解了!。
不同的事物,使用不同的编码方式可能得到相同的二进制码,而相同的二进制码,使用不同的解码方式会被理解为不同的事物!
从本质上来讲什么是数据类型?
其实就是数据的编解码的方式!!!
最后,什么是字符集?
就是对字符的编码解码的方式!
不同字符集,规定了字符的编码(字符转换为二进制数)和解码(二进制数转换为字符)方式。
System.out.println("你好".getBytes("utf-8") ); System.out.println("你好".getBytes("gbk") );
输出:
[B@677327b6
[B@14ae5a5
可以看到不同的字符集(utf-8和gbk)把相同的中文"你好",编码成了不同的二进制码。
当然,上面输出并不是0和1,显然不是二进制码。。。那是因为计算机显示的时候把二进制码使用ASCII码帮你解了码。。。都变成了ASCII字符。why?我并不想让它解码,但是显示就是解码!!!
当然通过一些技巧可以输出二进制的字符串,但是这个不是重点,这里就不给出了。
最后的最后
计算机最早在什么领域应用了编解码?
汇编语言!
计算机命令也是二进制码,把汇编语言的英语单词变成二进制码就是编码,而把二进制码变成汇编语言的单词就是解码!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/72191.html
摘要:要确保没有低估需要存储的值的范围,更小是相对与数据类型的最大值范围来讲的。如果无法确定哪个数据类型是最好的,就选择你认为不会超过范围的最小类型。整数类型有两个类型的数字整数和实数。列默认为,这与其他的数据类型不一样。 简述 良好的逻辑设计和物理设计是高性能系统的基石,比如反范式设计可以加快某些类型的查询同时也会影响另外一些类型的查询效率,所以我们必须重视Mysql对于数据库的设计(本...
摘要:要确保没有低估需要存储的值的范围,更小是相对与数据类型的最大值范围来讲的。如果无法确定哪个数据类型是最好的,就选择你认为不会超过范围的最小类型。整数类型有两个类型的数字整数和实数。列默认为,这与其他的数据类型不一样。 简述 良好的逻辑设计和物理设计是高性能系统的基石,比如反范式设计可以加快某些类型的查询同时也会影响另外一些类型的查询效率,所以我们必须重视Mysql对于数据库的设计(本...
阅读 565·2021-11-22 14:45
阅读 3051·2021-10-15 09:41
阅读 1494·2021-10-11 10:58
阅读 2674·2021-09-04 16:45
阅读 2584·2021-09-03 10:45
阅读 3217·2019-08-30 15:53
阅读 1203·2019-08-29 12:28
阅读 2101·2019-08-29 12:14