我刚刚完成了这个学期的计算机体系结构课程,除此之外,我们一直在涉足MIPS组装并在MARS模拟器中运行它.今天,出于好奇,我开始在我的Ubuntu盒子上搞乱NASM,基本上只是从教程中拼凑起来并了解NASM与MIPS的不同之处.以下是我目前正在查看的代码段:
global _start _start: mov eax, 4 mov ebx, 1 pop ecx pop ecx pop ecx mov edx, 200 int 0x80 mov eax, 1 mov ebx, 0 int 0x80
这将保存为test.asm,并与其组合nasm -f elf test.asm
并链接ld -o test test.o
.当我调用它时./test anArgument
,它按预期打印'anArgument',然后填充该字符串所需的许多字符总数为200个字符(因为该mov edx, 200
语句).但有趣的是,这些填充字符,我本来应该是胡言乱语,实际上是从我的环境变量的开头,如env
命令所示.为什么打印出我的环境变量?
在不知道实际答案或有时间查找的情况下,我猜测环境变量在命令行参数之后存储在内存中.您的代码只是缓冲区溢出到环境变量字符串并打印它们.
这实际上是有道理的,因为命令行参数由系统/加载器处理,环境变量也是如此,因此将它们存储在彼此附近是有意义的.要解决此问题,您需要找到命令行参数的长度,并且只打印那么多字符.或者,因为我假设它们是空终止字符串,所以打印直到达到零字节.
编辑:我假设命令行参数和环境变量都存储在初始化数据部分(我相信NASM中的.data)