它已被解释(在相关主题链接在下面的评论问题)如何静态变量的工作。
这里是由gcc为你的p1函数生成的实际代码(通过gcc -c -O0 -fomit -frame-pointer -g3 staticvar.c -o staticvar.o),然后用相关源进行反汇编。
Disassembly of section .text:
0000000000000000 :
#include
void p1(void)
{
0: 48 83 ec 08 sub $0x8,%rsp
static int x = 10;
x += 5;
4: 8b 05 00 00 00 00 mov 0x0(%rip),%eax # a
a: 83 c0 05 add $0x5,%eax
d: 89 05 00 00 00 00 mov %eax,0x0(%rip) # 13
printf("%d\n", x);
13: 8b 05 00 00 00 00 mov 0x0(%rip),%eax # 19
19: 89 c6 mov %eax,%esi
1b: bf 00 00 00 00 mov $0x0,%edi
20: b8 00 00 00 00 mov $0x0,%eax
25: e8 00 00 00 00 callq 2a
}
2a: 90 nop
2b: 48 83 c4 08 add $0x8,%rsp
2f: c3 retq
因此,正如您所看到的,没有声明x的代码。 GDB只能打破实际机器代码指令和作为没有,它打破上下一指令(MOV),它匹配线5