[oeasy]python0074[专业选修]字节序_byte_order_struct_pack_大端序_小端序
- 上次 总结了
- 计算字符串值的函数
- eval
- 四种进制的转化函数
- bin
- oct
- int
- hex
|
函数名
|
前缀
|
目标字符串所用进制
|
|---|---|---|
|
bin
|
0b
|
二进制
|
|
oct
|
0o
|
八进制
|
|
hex
|
0x
|
十六进制
|
|
eval
|
无前缀
|
十进制
|
- 数字41 和 字符串"41" 的不同
- 字符串"41"
- 两个字符
- 字符存储依据是 ascii序号
- b"\x34\x31"
- 数字 41
- 数字存储依据是 数字的二进制值
- 转化为 二进制 0b101001
- 字节前面补零
- 得到 b"\x00\x29"
- 这就两个字节
- 但是 这两个字节 在存储的时候
- 有先后次序吗?
- 258 这个数字
- 如果用两个字节存储的话
- 字节状态什么样子呢?
- 字节状态会是
- b"\x01\x02" 吗?
- 参考一个网站
- 打开网址
- 选择有符号双字节
- signed short
- 网站中显示结果
- 可以使用python
- 得到这两个字节的字节状态吗?
- 借助一个包
- struct
- 导入struct包,并查看手册
- import struct
- help(struct)
- 数据类型是 short
- 对应 两个字节有符号的 整型数字
- 对应的符号 是h
- 得到字节状态是b"\x02\x01"
- 不是应该对应着 b"\x01\x02"么?
- 这数字 可不能 读错写错啊?
- 这该 如何理解 呢?
- 这前后颠倒的问题
- 涉及到 一个东西叫做
- 字节序
- byte order
- 这些可选的修饰字符
- 暗示字节的次序
- 字节次序有两种
|
符号
|
英文名称
|
中文名称
|
|---|---|---|
|
<
|
little-endian
|
小字节序
|
|
>
|
big-endian
|
大字节序
|
- 把这个修饰字节序的字符放在类型h(short)前面
- <h : little-endian 2-byte
- >h : big-endian 2-byte
- 下面两个不同的字节次序
- 对应同一个数字
- 0x12345678
- BigEndian
- 从低地址开始
- 在高地址结束
- 也就是地址数值大的地方结束
- 所以叫BigEndian
- LittleEndian
- 从高地址开始
- 在低地址结束
- 也就是地址数值小的地方结束
- 所以叫LittleEndian
- <h 用的是小字节序
- 编码模式属于 little-endian
- 最低有效位(least significant byte)放在低地址 a
- 这是目前常用的指令集架构 ($x86、x86-64$) 用的字节序
- CISC(复杂指令集)
- 另一种字节序是大字节序
- 应用于 RISC(精简指令集)
- h 是按下图中的字节排序
- 编码模式属于 big-endian
- 最低有效位(most significant byte)落在高地址
- 这是目前 RISC 指令集架构 (RISC、MIPS) 用的字节序
- 也是我们看起来比较顺的字节序
- 这两个单词怎么来的呢?
- big-endian
- little-endian
- 主要指的是磕鸡蛋的时候用哪个头磕
- 大头
- 小头?
- 出现于《格列佛游记》
- 小人国为水煮蛋争论
- 争论的双方分别被称为“大端派”和“小端派”
- 以下是1726年关于大小端之争历史的描述
“我下面要告诉你的是,Lilliput和Blefuscu这两大强国在过去36个月里一直在苦战。战争开始是由于以下的原因:我们大家都认为,吃鸡蛋前,原始的方法是打破鸡蛋较大的一端,可是当今皇帝的祖父小时候吃鸡蛋,一次按古法打鸡蛋时碰巧将一个手指弄破了。因此他的父亲,当时的皇帝,就下了一道敕令,命令全体臣民吃鸡蛋时打破鸡蛋较小的一端,违令者重罚。老百姓们对这项命令极其反感。历史告诉我们,由此曾经发生过6次叛乱,其中一个皇帝送了命,另一个丢了王位。这些叛乱大多都是由Blefuscu的国王大臣们煽动起来的。叛乱平息后,流亡的人总是逃到那个帝国去寻求避难。据估计,先后几次有11000人情愿受死也不肯去打破鸡蛋较小的一端。关于这一争端,曾出版过几百本大部著作,不过大端派的书一直是受禁的,法律也规定该派任何人不得做官。”
- 这很像甜咸豆腐脑的争论
- 无关对错
- 只是个人习惯
- 能两种都吃的话
- 可以 增加食物多样性
- 我个人郑重推荐
- 加 韭菜花和辣椒油 少许
- 1980年
- Danny Cohen
- 一位网络协议的早期开发者
- 在其著名的论文"On Holy Wars and a Plea for Peace"中
- 为平息一场关于字节该以什么样的顺序传送的争论
- 而第一次引用了该词
- python默认用的是
- 什么字节序呢?
- python默认用
- 小端字节序
- 除了磕鸡蛋之外
- 鸡蛋放置也很有讲究
- 放置鸡蛋
- 要按照鸡蛋 自身的规律
- 大头里面 有空气
- 大头朝上 放的时间久一点
- 磕鸡蛋的时候
- 应该是磕哪头呢?
- 鸡蛋有内膜 叫做凤凰衣
- 可以外用
- 也可以内用
- 粉碎性地磕鸡蛋外壳
- 可以从小头附近 剥鸡蛋壳
- 连同鸡蛋内膜一起剥出来
- 手法要轻柔
- 否则 鸡蛋壳会感觉到疼
- 跳出大头小头二元对立
- 找到正确方法
- 完成任务
- 不产生绝对判断
- 不产生路径依赖
- 不断研究感受
- 找到最好的方法
- 随时接受教训
- 灵活应变
- 对自己的学习率敏感
- 这次我们研究了字节序
- 字节序有两种
|
符号
|
英文名称
|
中文名称
|
|---|---|---|
|
<
|
little-endian
|
小字节序
|
|
>
|
big-endian
|
大字节序
|
- 字节序 用来
- 明确 整型数字存储的 顺序
- 如果 读写数字出了错
- 可以 考虑一下
- 是否 字节序出了问题
- 变量现在可以
- 声明
- 初始化
- 存储了
- 但是 变量
- 又应该如何删除呢?
- 下次再说
[oeasy]python0074[专业选修]字节序_byte_order_struct_pack_大端序_小端序的更多相关文章
- C# 中大端序与小端序
C# 中大端序与小端序 static void Main(string[] args) { uint value = 0x12345678; Console.WriteLine("原始字节序 ...
- 大端模式 VS 小端模式
简单点说,就是字节的存储顺序,如果数据都是单字节的,那怎么存储无所谓了,但是对于多字节数据,比如int,double等,就要考虑存储的顺序了.注意字节序是硬件层面的东西,对于软件来说通常是透明的.再说 ...
- java音视频编解码问题:16/24/32位位音频byte[]转换为小端序short[],int[],以byte[]转short[]为例
前言:Java默认采用大端序存储方式,实际编码的音频数据是小端序,如果处理单8bit的音频当然不需要做转换,但是如果是16bit或者以上的就需要处理成小端序字节顺序. 注:大.小端序指的是字节的存储顺 ...
- 大端模式、小端模式和C#反转
A.C#大端模式和小端模式. 小端(little-endian)模式:低地址上存放低字节,高地址上存放高字节. 如0x11223344→ byte[] numBytes = new byte[]{ 0 ...
- 大端BigEndian、小端LittleEndian与字符集编码
BigEndian(大端):低字节在高内存地址 LittleEndian(小端):低字节在低内存地址 也就是看低字节在高内存地址还是低内存地址,也就是看低字节在前还是高字节在前,低字节在前自然是小端, ...
- 【C/C++开发】内存对齐(内存中的数据对齐)、大端模式及小端模式
数据对齐,是指数据所在的内存地址必须是该数据长度的整数倍.DWORD数据的内存起始地址能被4除尽,WORD数据的内存起始地址能被2除尽.X86 CPU能直接访问对齐的数据,当它试图访问一个未对齐的数据 ...
- 《Intel汇编第5版》 Intel CPU小端序
一.MASM汇编器中的数据类型 二.Intel汇编中的立即数类型 三.定义有符号和无符号整数 四.小端序 内存中数据按照字节存储,一个4个字节无符号整数,其高位存储在低地址上,低位存储在高地址上. 比 ...
- C语言--测试电脑存储模式(大端存储OR小端存储)
相信大家都知道大端存储和小端存储的概念,这在平时,我们一般不用考虑,但是,在某些场合,这些概念就显得很重要,比如,在 Socket 通信时,我们的电脑是小端存储模式,可是传送数据或者消息给对方电脑时, ...
- 小端存储转大端存储 & 大端存储转小端存储
1.socket编程常用的相关函数:htons.htonl.ntohs.ntohl h:host n:network s:string l:long 2.基本数据类型,2字节,4字 ...
- intel 系列的PC机处理器是大端的还是小端的?
intel 系列的PC机处理器是大端的还是小端的?由于要安装oracle,需要知道是大端机器还是小端的,你好,现在流行的PC,是微型处理器,也就是所谓的小端处理器. 大端处理器是由若干个微型处理器有机 ...
随机推荐
- 整理C语言预处理过程语法的实用方法与技巧
预处理 目录 预处理 一.宏定义 数值宏常量 字符串宏常量 用define宏定义注释符号? 程序的编译过程 预处理中宏替换和去注释谁先谁后? 如何写一个不会出现问题的宏函数 do-while-zero ...
- 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 ...
- 在Mac上运行Rainbond,10分钟快速安装
前言 以往安装部署 Rainbond 的方式都无法绕过 Kubernetes 集群的搭建,无论是作为开发环境还是用于生产交付,部署的过程都非常依赖于服务器或云主机.这在体验 Rainbond 云原生应 ...
- 记第一次用python写界面
花了两三个小时学了Tkinter,做了一个将数据绘制成图的小工具. 1. 获取路径下的所有文件or获取路径下指定名称的文件 1.1 打开文件 //1. 用来放文本框中的文字filename = St ...
- GNU GCC学习
1 Introduction 参考视频:1 GCC简介_哔哩哔哩_bilibili 参考书籍:<An Introduction to GCC (Brian J. Gough, Richard.p ...
- C语言-使用malloc导致的奔溃问题
在使用malloc.memset.free的过程中,出现了程序奔溃,大致现象如下. 程序的实现大致如下: #include <stdio.h> #include <stdlib.h& ...
- 知乎x-zse-96逆向分析
声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 aHR0cHM6 ...
- LeetCode 719. 找出第 k 小的距离对 (Java)
题目: 给定一个整数数组,返回所有数对之间的第 k 个最小距离.一对 (A, B) 的距离被定义为 A 和 B 之间的绝对差值. 示例 1: 输入:nums = [1,3,1]k = 1输出:0 解释 ...
- 喜讯!INFINI Easysearch 在墨天轮数据库排名中挺进前30!
近日,2023 年 10 月的 墨天轮中国数据库流行度排行 火热出炉,本月共有 283 个数据库参与排名,中国数据库行业竞争日益激烈.其中,极限科技旗下软件产品 INFINI Easysearch 稳 ...
- java并发编程——CompletableFuture
简介 Java的java.util.concurrent包中提供了并发相关的接口和类,本文将重点介绍CompletableFuture并发操作类 JDK1.8新增CompletableFuture该类 ...