程序启动时的堆栈
程序启动时,Linux把4种类型的信息存放到程序堆栈中:
(1)命令行参数(包括程序名称)的数目
(2)从shell提示符执行的程序的名称
(3)命令行中包含的任何命令行参数
(4)在程序启动时的所有当前Linux环境变量
程序名称、命令行参数和环境变量是以空结尾的长度可变的字符串。为了使工作更加简单,Linux不仅把字符串加载到堆栈中,它还把指向每个这些元素的指针加载到堆栈中,所以可以容易地在程序中定位它们。
程序启动时,堆栈的一般布局如下图所示:
在命令行参数之后,4字节的空值被存储到堆栈中,用于把参数和指向环境变量的指针的开始位置分隔开来。