- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是我的代码:
section .data
digit db 0,10
section .text
global _start
_start:
call _printRAXDigit
mov rax, 60
mov rdx, 0
syscall
_printRAXDigit:
add rax, 48
mov [digit], al
mov rax, 1
mov rdi, 1
mov rsi, digit
mov rdx, 2
syscall
ret
我对 [digit]
和 digit
之间的区别有疑问。
我了解到标签(如代码中的digit)代表数据的内存地址,运算符“[]”的作用类似于取消引用指针,因此它将加载标签指向目的地的值。
例如,mov rax, [digit]
会将 0 抛出到 rax
寄存器,因为 digit 指向数据的第一个元素(在本例中为整数 0)。
但是,在我的代码中,当我写 mov [digit], al
时它起作用了,这意味着“将存储在 al
中的值加载到内存地址 digit”,但我不知道为什么在这种情况下我们应该使用“[]”。 mov
的第一个参数必须是目标(如寄存器或内存地址),所以我认为它应该是 mov digit, al
而不是 mov [数字], al
.我不明白为什么我们使用一个值从另一个地方获取值而不是使用内存地址获取值。
这就是我的全部问题。请给我任何关于我的想法错误的地方或对我的标签概念的任何纠正。
最佳答案
在 NASM 语法中(有使用不同符号的汇编程序,例如 MASM/TASM use a different flavor of Intel syntax ,而 gas 使用 AT&T syntax )以下 x86 指令......
mov esi, someAddress
mov esi, [someAddress]
mov [someAddress], esi
mov someAddress, esi ; see below
...(将)具有以下含义:
mov esi, someAddress
将表示someAddress
存储地址的数字写入寄存器esi
。因此,如果 someAddress
存储在地址 1234,则值 1234 将写入 esi
。
mov esi, [someAddress]
将内存的内容写入esi
。因此,如果 someAddress
存储在地址 1234 并且存储在地址 1234 的值是 5678,则将值 5678 写入 esi
。
你也可以说:变量 someAddress
的值(一个变量通常只是内存中某个地址的内容)被写入 esi
注册。
mov [someAddress], esi
将esi
的内容写入内存地址someAddress
。
你也可以说:将esi
的值写入变量someAddress
。
mov someAddress, esi
会的意思是:将代表地址someAddress
的常量数更改为esi
。
因此,如果 someAddress
位于地址 1234 并且 esi
包含值 5678,则指令将意味着:
以 1234 = 5678 的方式更改数学常数 1234。
这当然很愚蠢,因为数学常数 1234 和 5678 永远不会相等。因此 x86 CPU 没有这样的指令。
(有些 CPU 有类似的指令。例如,在 SPARC CPU 上,如果您只想让指令的一侧有一个值给零寄存器的指令(这意味着:“给常量零赋值”)效果 - 就像设置标志 - 但你对结果本身不感兴趣。)
关于linux - 对 X86_64 linux : Why should we write mov [digit], al 的程序集中标签的使用感到困惑,但不是 mov digit, al?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46861519/
这个问题在这里已经有了答案: Differences between general purpose registers in 8086: [bx] works, [cx] doesn't? (3
我最近开始探索计算机体系结构领域。在研究指令集体系结构时,我遇到了“ mov”指令,该指令将数据从一个位置复制到另一个位置。我知道某些类型的mov'指令是有条件的,而有些则需要添加偏移量或位移来查找特
我正在研究使用模拟 MSP430 CPU 的 Microcorruption CTF。 我见过几个 mov 指令示例,例如: mov sp, r4 ;将堆栈指针的值移至寄存器4 mov #0xfffc
我不明白 MOV 和 MOV ptr 之间的区别。 例如,在这段 C 代码中: unsigned char x, y; x = 2; 汇编中的第二行是: `MOV x, 2` 但是这个 C 代码的第二
MOV可能是每个人在学习ASM时都会学到的第一条指令。 刚才我遇到了一本书Assembly Language Programming in GNU/Linux for IA32 Architectur
下面两行有什么区别? mov ax, bx mov ax, [bx] 如果bx包含值100h,并且内存地址100h处的值是23,那么第二个是否将23复制到ax? 另外,下面两行有什么区别? mov a
我编写了一个基本的 C 程序,它定义了一个整型变量 x,将其设置为零并返回该变量的值: #include int main(int argc, char **argv) { int x;
我是一个初学者,正在编写汇编程序以使用以下代码打印从 1 到 9 的数字: section .text global _start _start:
mov (%rax),%eax有什么区别和 mov %rax,%eax ?我确定这是一个简单的问题,但我在任何地方都找不到答案。 这是提示我的问题的原始代码: mov -0x8(%rbp),%r
有人可以解释一下这三个指令的功能吗? ORG 1000H MOV AX,CS MOV DS,AX 我知道理论上的代码、数据和额外段是什么,但是: 在这个程序中它们是如何实现的? 为什么整个
在 8086 架构的 16 位 MS-DOS 应用程序中,mov bx,ax 和 mov bh,ah 之间的速度有区别吗? 最佳答案 您没有指定架构,但至少在 8086 中指定, 286 , 386和
我正在反汇编一些代码,我发现: mov eax, cr3 mov cr3, eax 这些线的作用是什么? 这是 x86 低级(BIOS/固件/引导加载程序之前)初始化代码。我们甚至还没有设置缓存。 最
使用 nasm 组装此代码时: BITS 64 mov eax, 0x1 mov rax, 0x1 我得到这个输出: b8 01 00 00 00 b8 01 00 00 00 这是 mov eax,
我试图理解 Intel 语法和 AT&T 语法之间的差异(我使用 GNU as)。 我有两个文件,intel.s: .intel_syntax noprefix val: mov eax, v
我需要一种非常精确的方法来加速音频。 我正在为 OpenDCP(一种用于制作数字电影包的开源工具)准备电影,以便在影院放映。 我的源文件通常是 23.976fps 和 48.000kHz 音频的 qu
通过查看英特尔指令卷,我发现了这一点: 1) 88/r MOV r/m8,r8 2) 8A/r MOV r8,r/m8 当我在 NASM 中写下这样的一行,并使用列表选项将其组装时: mov al
Intel 手册说 mov 有两种变体,涉及内存和 32 位立即操作数: MOV r/m32, imm32 MOV r/m64, imm32 第一个复制四个字节,第二个复制八个字节,采用给定的 32
我已经处理了一天了,最后不得不出来问。我想获取一个无声的 prores mov 文件(但显然确实有时间码轨道)并将其与 6 个单声道 wav 文件无损混合,使 6 个单声道 wav 在最终 mov 中
这是我的代码: section .data digit db 0,10 section .text global _start _start: call _printRAXD
我在问 mov需要计算该地址的指令,即(在 at&t 语法中mov i(r, r, i), reg或 mov reg, i(r, reg, i)必须在端口 1 上执行,因为它们实际上是带有 3 个操作
我是一名优秀的程序员,十分优秀!