大家先看一下这段程序:
pushl %ebp 将当前的基址存储,函数退出时用
movl %esp, %ebp 当前函数的基址
subl $16, %esp 在栈中,分配16个字节来存储局部的变量
movl 8(%ebp), %eax 调用main()函数的地方,返回值会存储在这里。(很显然,没有函数调用main(),这个地址很不确定)
movb $0, -1(%ebp) 为xingwang.sex赋值
movzbl -1(%ebp), $edx
movb %dl, (%eax) 将xingwang赋值给eax指向的内存地址
问题就出在 movl 8(%ebp), %eax 这一行。使用GDB调试以后发现,%ebp+8这个位置的值是 0x1,也就是说函数最后的返回值要存储给0x1这个内存单元。很显然这个内存单元不是用户可以操作的。
所以,这个C程序最后运行时,会提示 段错误 或者 Segment Fault。