进制转化
回忆上次内容
-
四种进制的转化函数
-
bin
-
oct
-
int
-
hex
-
数字41 和 字符串"41" 的不同
-
字符串"41"
-
两个字符
-
字符存储依据是 ascii序号
-
b"\x34\x31"
-
数字 41
-
数字存储依据是 数字的二进制值
-
转化为 二进制 0b101001
-
字节前面补零
-
得到 b"\x00\x29"
-
但是 这两个字节 在存储的时候
-
有先后次序吗?????
存储
-
258 这个数字
-
如果用两个字节存储的话
-
字节状态什么样子呢?
观察网站
选择结果
-
可以使用python
-
得到这两个字节的字节状态吗?
struct
-
导入struct包,并查看手册
-
import struct
-
help(struct)
-
数据类型是 short
-
对应 两个字节有符号的 整型数字
-
对应的符号 是h
得到字节状态
-
这数字 可不能 读错写错啊?
-
这该 如何理解 呢?
字节序
-
这前后颠倒的问题
-
涉及到 一个东西叫做
-
字节序
-
byte order
字节序对比
-
下面两个不同的字节次序
-
对应同一个数字
-
0x12345678
-
BigEndian
-
从低地址开始
-
在高地址结束
-
也就是地址数值大的地方结束
-
所以叫BigEndian
-
LittleEndian
-
从高地址开始
-
在低地址结束
-
也就是地址数值小的地方结束
-
所以叫LittleEndian
little-endian < h
-
另一种字节序是大字节序
-
应用于 RISC(精简指令集)
big-endian >h
-
这两个单词怎么来的呢?
-
big-endian
-
little-endian
词汇来源
-
出现于《格列佛游记》
-
小人国为水煮蛋争论
-
争论的双方分别被称为“大端派”和“小端派”
-
以下是1726年关于大小端之争历史的描述
“我下面要告诉你的是,Lilliput和Blefuscu这两大强国在过去36个月里一直在苦战。战争开始是由于以下的原因:我们大家都认为,吃鸡蛋前,原始的方法是打破鸡蛋较大的一端,可是当今皇帝的祖父小时候吃鸡蛋,一次按古法打鸡蛋时碰巧将一个手指弄破了。因此他的父亲,当时的皇帝,就下了一道敕令,命令全体臣民吃鸡蛋时打破鸡蛋较小的一端,违令者重罚。老百姓们对这项命令极其反感。历史告诉我们,由此曾经发生过6次叛乱,其中一个皇帝送了命,另一个丢了王位。这些叛乱大多都是由Blefuscu的国王大臣们煽动起来的。叛乱平息后,流亡的人总是逃到那个帝国去寻求避难。据估计,先后几次有11000人情愿受死也不肯去打破鸡蛋较小的一端。关于这一争端,曾出版过几百本大部著作,不过大端派的书一直是受禁的,法律也规定该派任何人不得做官。”
后续
-
1980年
-
Danny Cohen
-
一位网络协议的早期开发者
python默认字节序
生活细节
按规律办事
磕鸡蛋的细节
-
粉碎性地磕鸡蛋外壳
-
可以从小头附近 剥鸡蛋壳
-
连同鸡蛋内膜一起剥出来
寻道
禅意
总结
-
如果 读写数字出了错
-
可以 考虑一下
-
是否 字节序出了问题
-
下次再说????
-
蓝桥->
-
github->
-
gitee->
阅读(179) | 评论(0) | 转发(0) |