如何解决GLOBAL__I_main函数
| 我反汇编了用C ++编写的简单程序,并且有一个功能:080486a8 <_GLOBAL__I_main>:
80486a8: 55 push %ebp
80486a9: 89 e5 mov %esp,%ebp
80486ab: 83 ec 18 sub $0x18,%esp
80486ae: c7 44 24 04 ff ff 00 movl $0xffff,0x4(%esp)
80486b5: 00
80486b6: c7 04 24 01 00 00 00 movl $0x1,(%esp)
80486bd: e8 a6 ff ff ff call 8048668 <_Z41__static_initialization_and_destruction_0ii>
80486c2: c9 leave
80486c3: c3 ret
80486c4: 90 nop
80486c5: 90 nop
80486c6: 90 nop
80486c7: 90 nop
80486c8: 90 nop
80486c9: 90 nop
80486ca: 90 nop
80486cb: 90 nop
80486cc: 90 nop
80486cd: 90 nop
80486ce: 90 nop
80486cf: 90 nop
这有什么作用?为何在RET指令后有那么多的nop操作?
解决方法
正如netrom所提到的,“ 1”安排了全局构造函数和析构函数的调用。
许多编译器在函数后添加“ 2”指令以启用增量重新链接。如果您稍微更改一下函数并且函数不断增加,则链接器不必移动所有后续函数。相反,增长覆盖了一些以前的增长。
, 如果拆开
__Z41__static_initialization_and_destruction_0ii
,则得到
__static_initialization_and_destruction_0(int,int)
。
看看这个答案,甚至这个文件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。