数据的处理1 (深入理解计算机系统)

  1. 整数和浮点数的运算
(3.14 + 1e20) - 1e20
#result: 0
3.14 + (1e20 - 1e20)
#result: 3.14

在底层的代码中,计算机是不能做不同类型数据之间的运算的,对于CPU来说,是不分类型只认识二进制的.
int 表示一个较小的数值范围,但是是精确的, 而float 表示一个较大的数值范围,但是是近似的.
在有些高级语言中,如python javascript 等, 语法中自带隐式转换, 可以把float转换成int类型而失去精度, 或者是把int转换成float类型再进行计算. 而一些低级语言. 如c c++等, 语法中不带隐式转换, 或许在计算结果中会给予警告,或许不警告就会成为一个BUG,那么就必须人工进行显示类型转换

  1. 字节顺序
# long a = 0x01234567
大端法:
0x100	0x101	0x102	0x103
01		23		45		67
小端法:
0x100	0x101	0x102	0x103
67		45		23		01
#0x100 是a的内存地址, &a

不同机器和操作系统的编码是不一样的,有些机器是允许大/小端编码的,有些是只允许其中之一. 比如IBM SUN公司的产品,是大端模式, 而大多数机器都是小端模式, win linux也都是小端模式, android ios也都是小端模式, 了解这些对网络编程的数据流BUG有着很大的意义.

二进制数据与字符数据的优劣
二进制数据比字符数据有明显的速度快容量小的优点,但是字符数据比二进制数据有着更强的平台独特性
ASCII码占位是1字节,上面的代码块的数据类型是long 占64位就是8字节,大端法和小端法之间的区别仅仅是在一个数据块中的排列顺序,而单字节和数据块的顺序都是相同的,所以对于单字节序列来说,可以跨越不同机器和操作系统进行移植和传输.
现在流行的unicode utf-8 编码则会有所不同,

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值