问题描述
如果 C 程序更改字节数组中的一个字节,会执行哪些机器指令?硬件是否需要读取 8 个字节,更改一个字节并存储(使用 2 次内存操作)?
编辑:专门针对 x86-64 架构
解决方法
在 x86-64 上,硬件将读取一个缓存行,修改缓存中的字节,最终该缓存行将被写回内存。
发生回写的主要原因是 CPU 需要缓存线来存储其他数据。有强制回写的明确指令,但 C 编译器不太可能使用这些指令。它会降低 CPU 的速度以强制进行不必要的写入。
,这完全取决于编译器、优化等。只需尝试编译和反汇编即可。作为示例,我们将编译以下代码:
#include <stdio.h>
int main() {
char a[] = "01234567890";
a[5] = 'A';
printf("%s\n",a);
}
// gcc -o main -std=c11 -Wall -Wextra -O0 main.c
我们通过 objdump
获得反汇编:
6c1: 48 b8 30 31 32 33 34 movabs rax,0x3736353433323130
6c8: 35 36 37
6cb: 48 89 45 ec mov QWORD PTR [rbp-0x14],rax
6cf: c7 45 f4 38 39 30 00 mov DWORD PTR [rbp-0xc],0x303938
6d6: c6 45 f1 41 mov BYTE PTR [rbp-0xf],0x41
6da: 48 8d 45 ec lea rax,[rbp-0x14]
6de: 48 89 c7 mov rdi,rax
// objdump -d ./main -Mintel | less