进制转化
回忆上次内容
  • 上次 总结了
  • 计算字符串值的函数
  • eval
 
  • 四种进制的转化函数
  • bin
  • oct
  • int
  • hex
 
 
函数名
前缀
目标字符串所用进制
bin
0b
二进制
oct
0o
八进制
hex
0x
十六进制
eval
无前缀
十进制
 

 
添加图片注释,不超过 140 字(可选)
 
  • 数字41 和 字符串"41" 的不同
  • 字符串"41"
  • 两个字符
  • 字符存储依据是 ascii序号
  • b"\x34\x31"
 
  • 数字 41
  • 数字存储依据是 数字的二进制值
  • 转化为 二进制 0b101001
  • 字节前面补零
  • 得到 b"\x00\x29"
 
  • 这就两个字节
 
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 但是 这两个字节 在存储的时候
  • 有先后次序吗?
 
存储
  • 258 这个数字
  • 如果用两个字节存储的话
  • 字节状态什么样子呢?
 
 
  • 字节状态会是
  • b"\x01\x02" 吗?
 
 

 
添加图片注释,不超过 140 字(可选)
 
 
观察网站
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 选择有符号双字节
  • signed short
 
选择结果
  • 网站中显示结果
 

 
添加图片注释,不超过 140 字(可选)
 
  • 可以使用python
  • 得到这两个字节的字节状态吗?
 
  • 借助一个包
  • struct
 
struct
  • 导入struct包,并查看手册
  • import struct
  • help(struct)
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 数据类型是 short
  • 对应 两个字节有符号的 整型数字
  • 对应的符号 是h
 
得到字节状态
  • 得到字节状态是b"\x02\x01"
 

 
添加图片注释,不超过 140 字(可选)
 
  • 不是应该对应着 b"\x01\x02"么?
 

 
添加图片注释,不超过 140 字(可选)
 
  • 这数字 可不能 读错写错啊?
  • 这该 如何理解 呢?
字节序
  • 这前后颠倒的问题
  • 涉及到 一个东西叫做
  • 字节序
  • byte order
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 这些可选的修饰字符
  • 暗示字节的次序
 
  • 字节次序有两种
符号
英文名称
中文名称
<
little-endian
小字节序
>
big-endian
大字节序
 

 
添加图片注释,不超过 140 字(可选)
 
  • 把这个修饰字节序的字符放在类型h(short)前面
  • <h : little-endian 2-byte
  • >h : big-endian 2-byte
 
字节序对比
  • 下面两个不同的字节次序
  • 对应同一个数字
  • 0x12345678
 
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • BigEndian
  • 从低地址开始
  • 在高地址结束
  • 也就是地址数值大的地方结束
  • 所以叫BigEndian
 
  • LittleEndian
  • 从高地址开始
  • 在低地址结束
  • 也就是地址数值小的地方结束
  • 所以叫LittleEndian
 
little-endian < h
  • <h 用的是小字节序
  • 编码模式属于 little-endian
  • 最低有效位(least significant byte)放在低地址 a
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 这是目前常用的指令集架构 ($x86、x86-64$) 用的字节序
  • CISC(复杂指令集)
 
  • 另一种字节序是大字节序
  • 应用于 RISC(精简指令集)
 
big-endian >h
  • h 是按下图中的字节排序
  • 编码模式属于 big-endian
  • 最低有效位(most significant byte)落在高地址
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 这是目前 RISC 指令集架构 (RISC、MIPS) 用的字节序
  • 也是我们看起来比较顺的字节序
 
  • 这两个单词怎么来的呢?
  • big-endian
  • little-endian
 
词汇来源
  • 主要指的是磕鸡蛋的时候用哪个头磕
  • 大头
  • 小头?
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 出现于《格列佛游记》
  • 小人国为水煮蛋争论
  • 争论的双方分别被称为“大端派”和“小端派”
  • 以下是1726年关于大小端之争历史的描述
 
“我下面要告诉你的是,Lilliput和Blefuscu这两大强国在过去36个月里一直在苦战。战争开始是由于以下的原因:我们大家都认为,吃鸡蛋前,原始的方法是打破鸡蛋较大的一端,可是当今皇帝的祖父小时候吃鸡蛋,一次按古法打鸡蛋时碰巧将一个手指弄破了。因此他的父亲,当时的皇帝,就下了一道敕令,命令全体臣民吃鸡蛋时打破鸡蛋较小的一端,违令者重罚。老百姓们对这项命令极其反感。历史告诉我们,由此曾经发生过6次叛乱,其中一个皇帝送了命,另一个丢了王位。这些叛乱大多都是由Blefuscu的国王大臣们煽动起来的。叛乱平息后,流亡的人总是逃到那个帝国去寻求避难。据估计,先后几次有11000人情愿受死也不肯去打破鸡蛋较小的一端。关于这一争端,曾出版过几百本大部著作,不过大端派的书一直是受禁的,法律也规定该派任何人不得做官。”
  • 这很像甜咸豆腐脑的争论
  • 无关对错
  • 只是个人习惯
 
  • 能两种都吃的话
  • 可以 增加食物多样性
 
  • 我个人郑重推荐
  • 加 韭菜花和辣椒油 少许
 
后续
  • 1980年
  • Danny Cohen
  • 一位网络协议的早期开发者
 
  • 在其著名的论文"On Holy Wars and a Plea for Peace"中
  • 为平息一场关于字节该以什么样的顺序传送的争论
  • 而第一次引用了该词
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • python默认用的是
  • 什么字节序呢?
 
python默认字节序
 

 
添加图片注释,不超过 140 字(可选)
 
  • python默认用
  • 小端字节序
 
 

 
添加图片注释,不超过 140 字(可选)
 
生活细节
  • 除了磕鸡蛋之外
  • 鸡蛋放置也很有讲究
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 放置鸡蛋
  • 要按照鸡蛋 自身的规律
 
按规律办事
  • 大头里面 有空气
  • 大头朝上 放的时间久一点
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 磕鸡蛋的时候
  • 应该是磕哪头呢?
 
磕鸡蛋的细节
  • 鸡蛋有内膜 叫做凤凰衣
  • 可以外用
  • 也可以内用
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 粉碎性地磕鸡蛋外壳
  • 可以从小头附近 剥鸡蛋壳
  • 连同鸡蛋内膜一起剥出来
 
 
  • 手法要轻柔
  • 否则 鸡蛋壳会感觉到疼
 
寻道
  • 跳出大头小头二元对立
 

 
添加图片注释,不超过 140 字(可选)
 
  • 找到正确方法
 

 
添加图片注释,不超过 140 字(可选)
 
  • 完成任务
禅意
  • 不产生绝对判断
  • 不产生路径依赖
 
  • 不断研究感受
  • 找到最好的方法
 
 

 
添加图片注释,不超过 140 字(可选)
 
  • 随时接受教训
  • 灵活应变
  • 对自己的学习率敏感
 
总结
  • 这次我们研究了字节序
  • 字节序有两种
 
符号
英文名称
中文名称
<
little-endian
小字节序
>
big-endian
大字节序
  • 字节序 用来
  • 明确 整型数字存储的 顺序
 
  • 如果 读写数字出了错
  • 可以 考虑一下
  • 是否 字节序出了问题
 
 
  • 变量现在可以
  • 声明
  • 初始化
  • 存储了
 
  • 但是 变量
  • 又应该如何删除呢?
 

[oeasy]python0074[专业选修]字节序_byte_order_struct_pack_大端序_小端序的更多相关文章

  1. C# 中大端序与小端序

    C# 中大端序与小端序 static void Main(string[] args) { uint value = 0x12345678; Console.WriteLine("原始字节序 ...

  2. 大端模式 VS 小端模式

    简单点说,就是字节的存储顺序,如果数据都是单字节的,那怎么存储无所谓了,但是对于多字节数据,比如int,double等,就要考虑存储的顺序了.注意字节序是硬件层面的东西,对于软件来说通常是透明的.再说 ...

  3. java音视频编解码问题:16/24/32位位音频byte[]转换为小端序short[],int[],以byte[]转short[]为例

    前言:Java默认采用大端序存储方式,实际编码的音频数据是小端序,如果处理单8bit的音频当然不需要做转换,但是如果是16bit或者以上的就需要处理成小端序字节顺序. 注:大.小端序指的是字节的存储顺 ...

  4. 大端模式、小端模式和C#反转

    A.C#大端模式和小端模式. 小端(little-endian)模式:低地址上存放低字节,高地址上存放高字节. 如0x11223344→ byte[] numBytes = new byte[]{ 0 ...

  5. 大端BigEndian、小端LittleEndian与字符集编码

    BigEndian(大端):低字节在高内存地址 LittleEndian(小端):低字节在低内存地址 也就是看低字节在高内存地址还是低内存地址,也就是看低字节在前还是高字节在前,低字节在前自然是小端, ...

  6. 【C/C++开发】内存对齐(内存中的数据对齐)、大端模式及小端模式

    数据对齐,是指数据所在的内存地址必须是该数据长度的整数倍.DWORD数据的内存起始地址能被4除尽,WORD数据的内存起始地址能被2除尽.X86 CPU能直接访问对齐的数据,当它试图访问一个未对齐的数据 ...

  7. 《Intel汇编第5版》 Intel CPU小端序

    一.MASM汇编器中的数据类型 二.Intel汇编中的立即数类型 三.定义有符号和无符号整数 四.小端序 内存中数据按照字节存储,一个4个字节无符号整数,其高位存储在低地址上,低位存储在高地址上. 比 ...

  8. C语言--测试电脑存储模式(大端存储OR小端存储)

    相信大家都知道大端存储和小端存储的概念,这在平时,我们一般不用考虑,但是,在某些场合,这些概念就显得很重要,比如,在 Socket 通信时,我们的电脑是小端存储模式,可是传送数据或者消息给对方电脑时, ...

  9. 小端存储转大端存储 & 大端存储转小端存储

    1.socket编程常用的相关函数:htons.htonl.ntohs.ntohl h:host   n:network      s:string    l:long 2.基本数据类型,2字节,4字 ...

  10. intel 系列的PC机处理器是大端的还是小端的?

    intel 系列的PC机处理器是大端的还是小端的?由于要安装oracle,需要知道是大端机器还是小端的,你好,现在流行的PC,是微型处理器,也就是所谓的小端处理器. 大端处理器是由若干个微型处理器有机 ...

随机推荐

  1. 整理C语言预处理过程语法的实用方法与技巧

    预处理 目录 预处理 一.宏定义 数值宏常量 字符串宏常量 用define宏定义注释符号? 程序的编译过程 预处理中宏替换和去注释谁先谁后? 如何写一个不会出现问题的宏函数 do-while-zero ...

  2. request to https://registry.npm.taobao.org/cnpm failed, reason: certificate has expired

    换华为的,否则会出问题:cnpm confg set registry https://mirrors.huaweicloud.com/repository/npm/ npm ERR! code CE ...

  3. 在Mac上运行Rainbond,10分钟快速安装

    前言 以往安装部署 Rainbond 的方式都无法绕过 Kubernetes 集群的搭建,无论是作为开发环境还是用于生产交付,部署的过程都非常依赖于服务器或云主机.这在体验 Rainbond 云原生应 ...

  4. 记第一次用python写界面

    花了两三个小时学了Tkinter,做了一个将数据绘制成图的小工具. 1. 获取路径下的所有文件or获取路径下指定名称的文件 1.1  打开文件 //1. 用来放文本框中的文字filename = St ...

  5. GNU GCC学习

    1 Introduction 参考视频:1 GCC简介_哔哩哔哩_bilibili 参考书籍:<An Introduction to GCC (Brian J. Gough, Richard.p ...

  6. C语言-使用malloc导致的奔溃问题

    在使用malloc.memset.free的过程中,出现了程序奔溃,大致现象如下. 程序的实现大致如下: #include <stdio.h> #include <stdlib.h& ...

  7. 知乎x-zse-96逆向分析

    声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 aHR0cHM6 ...

  8. LeetCode 719. 找出第 k 小的距离对 (Java)

    题目: 给定一个整数数组,返回所有数对之间的第 k 个最小距离.一对 (A, B) 的距离被定义为 A 和 B 之间的绝对差值. 示例 1: 输入:nums = [1,3,1]k = 1输出:0 解释 ...

  9. 喜讯!INFINI Easysearch 在墨天轮数据库排名中挺进前30!

    近日,2023 年 10 月的 墨天轮中国数据库流行度排行 火热出炉,本月共有 283 个数据库参与排名,中国数据库行业竞争日益激烈.其中,极限科技旗下软件产品 INFINI Easysearch 稳 ...

  10. java并发编程——CompletableFuture

    简介 Java的java.util.concurrent包中提供了并发相关的接口和类,本文将重点介绍CompletableFuture并发操作类 JDK1.8新增CompletableFuture该类 ...