- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
尽管单词的通用定义(维基百科上的 as stated)是:
The largest possible address size, used to designate a location in memory, is typically a hardware word (here, "hardware word" means the full-sized natural word of the processor, as opposed to any other definition used).
In the x86 PC (Intel, AMD, etc.), although the architecture has longsupported 32-bit and 64-bit registers, its native word size stems backto its 16-bit origins, and a "single" word is 16 bits. A "double" wordis 32 bits. See 32-bit computer and 64-bit computer.
this means the bytes of a word are numbered starting from the least significant byte. Figure 1-1 illustrates these conventions.
.text segment buffer:
< 0x10, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, 0x20 > ....
我会将第一条指令解析为 1C、1B、1A、10、20、1F、1E、1D ... (依此类推,长度可变,显然可能需要读取更多的单词,具体取决于此处的实际字节)
?
最佳答案
不,x86 机器码是 byte-stream ;除了 32 位位移和小端的立即数之外,它没有任何面向单词的东西。例如在 add qword [rdi + 0x1234], 0xaabbccdd
.它在现代 CPU 上以 16 字节或 32 字节 block 的形式物理获取,并在指令边界上并行拆分以并行馈送到解码器。
48 81 87 34 12 00 00 dd cc bb aa
REX.W add ModRM le32 0x1234 le32 0xaabbccdd le32 (sign-extended to 64-bit)
add QWORD PTR [rdi+0x1234],0xffffffffaabbccdd
x86-64 不是面向字的架构;没有单一的自然字长,也不必对齐 .在考虑 x86-64 时,这个概念并不是很有用。整数寄存器宽度恰好是 8 个字节,但这甚至不是机器代码中的默认操作数大小,您可以在大多数指令中使用从字节到 qword 的任何操作数大小,对于从 8 或 16 字节到 32 字节的 SIMD或 64 字节。最重要的是,机器代码甚至数据都不需要对齐更宽的整数。
add ax, cx
以避免将进位传播到寄存器的高位。虽然 RISC 可以执行在对符号扩展或零扩展加载结果进行一些数学运算后进行 16 位存储)。
according to some sources, note it's treated as 16 bits:
paddw
packed add of 16-bit SIMD elements , 和
movsw/stosw
/ETC。字符串指令。
关于x86-64 - 在 Intel x86-64 架构上是否以 little endian 4 字节字获取机器代码指令?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68229585/
this post完美地描述了我的原始问题:我想遵循TDD: 写一个小测试 观看失败 写足够的代码使它成功 观看成功 重复 我正在IntelliJ中从事Grails项目。如果我只想编写普通的JUnit
据我所知,little-oh 应该有一个接近无穷大的 n 的极限(函数/little-oh,omega 函数)= 0,对于 little omega,极限应该等于无穷大。但是,是否有可能存在多个 li
您好,我目前正在使用 Little Man Computer对于一个学校项目,我知道 LMC 有一个 ADD 和一个 SUB 功能。但是我知道 LMC 中没有乘法或除法函数,我想知道为什么会这样。 最
little-oh 和 little Omega 符号的用途/目的是什么? 尽管我完全理解符号本身及其代表的含义。我还没有看到任何一本书或算法在任何计算中使用它们,所以我不禁想知道如果不使用它们,为什
我正在阅读“小计划者”,以更好地理解编程的某些核心元素(即递归),并获得更多关于如何像程序员一样思考的想法。 这本书被推荐作为入门级书籍,并且在引言中指出,我所需要知道的只是英文,数字和计数(我会这样
考虑以下 s 表达式: ((lambda (car) (car (quote (a b c)))) cdr) 在我尝试过的大多数方案实现中,计算结果为 (b c)因为cdr传递给 lambda,将其命
我的目标是拥有一个在后台运行的服务,并以指定的时间间隔(例如每 10 分钟)将我的设备位置发送到远程服务器。我正在尝试使用 Little Fluffy Location Library 来优化电池生命
我刚刚学习了 Python (3.x),但我一直在将十六进制字符串转换为 float 。我有这个十六进制字符串值:'0x22354942F31AFA42CE6A494311518A43082CAF43
所以,我可以理解为 0x1234 的一个字,当存储为 little-endian 时,在内存中变为 0x3412。我还看到字节 0x12 作为位域 a:4,b:4 将存储为 0x21。但是,如果我有更
我有一个 C 程序,它通过套接字在 UDP 数据包中从大型机接收数据。 C 程序的主机正在从 Unix(大端)更改为 Linux(小端),程序不再运行。我目前没有更改大型机客户端程序的选项。 程序执行
我正在使用 PulseAudio API“实时”获取当前麦克风输入。缓冲区数据作为 16 位小端字节数组传送。我想做的是找出缓冲区中的最大峰值电平并将其转换为分贝值。为此,我必须将每两个字节数组值转换
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
这个问题在这里已经有了答案: Difference between Big-O and Little-O Notation (5 个答案) 关闭 8 年前。 直观上,nb = o(an)(o 是小哦
我正在使用 file.readAsBytes()。但它只提供List来接收数据。我正在尝试 Uint8List 但没有用。 最佳答案 readAsBytes将为您提供字节列表。它可能是一个 Uint8
我想快速了解 F# 并且想知道“The Little ML'er”这本书是否会有所帮助,因为 F# 基于 OCaml,它是 ML 的衍生物。或者,ML 与 F# 的差别太大而没有任何帮助吗? 谢谢。
将小端系统中的数据转换为网络字节顺序所需的底层转换是什么?对于2字节和4字节数据,有众所周知的函数(如htons,ntohl等)来封装变化,1字节数据的字符串(如果有的话)会发生什么? 此外,维基百科
我很难理解 The Little Schemer 的 evens-only*&co 发生了什么事情第 145 页的示例。 这是代码: (define evens-only*&co (lambda (
在从SICP学习了一些Scheme之后,我开始阅读The Little Schemer(我觉得很有趣),并且完成了大约四分之一。我注意到,无需使用lambda即可编写许多(大多数?全部?)解决方案,而
我正在尝试了解计算机的实际工作原理,我找到了一些模拟器软件,但它们似乎非常复杂(我还是个初学者)。我看到了Little Man Computer (LMC)这是很旧的。恐怕软件的工作方式与现在完全不同
我正在尝试了解计算机的实际工作原理,我找到了一些模拟器软件,但它们似乎非常复杂(我还是个初学者)。我看到了Little Man Computer (LMC)这是很旧的。恐怕软件的工作方式与现在完全不同
我是一名优秀的程序员,十分优秀!