装载、链接与库——main函数的前世今生

*当执行”Hello World“程序时,是从main函数开始执行的吗?答案当然是No,No,No!*

一个程序的运行步骤如下:

  • 操作系统在在创建进程后,把控制权交给了程序的入口,这个入口一般是运行库中的某个入口函数

  • 入口函数对运行库和程序运行环境进行初始化,包括堆、I/O、线程、全局变量构造等

  • 入口函数完成初始化后,调用main函数,正式开始执行程序主体部分

  • main函数执行完毕后,返回到入口函数,入口函数进行清理工作,包括全局变量析构、堆销毁、关闭I/O等,然后进行系统调用结束进程

接下来具体分析的是基于glibc 2.6.1中静态链接的、用于可执行文件的情况

  1. 第一步:glibc的程序入口为_start(这个入口是有ld链接器默认的链接脚本指定的,可以通过相关参数设定入口)

    • _start由汇编实现且和平台相关

      //将汇编改写为伪代码
      void start()
      {
          %ebp = 0;//使ebp为0,证明其是最外层函数
          int argc = pop from stack;//从栈中获取argc,隐含envp
          char **argv = top from stack;//从栈中获取argv
          //调用_libc_start_main()函数
          _libc_start_main(main, argc, argv, _libc_csu_init, _libc_csu_fini, edx, top of stack);
      }
    • 栈分布情况

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值