临时数据如何存储在堆栈帧上

问题描述 投票:1回答:1
Int test(){
    char buff[10]

    printf("Enter text: ");

    gets(buff);

    puts(buff);
}

我不知道如何表达这个问题,但我试图理解如何将值存储在堆栈帧上为局部变量分配的缓冲区上。

---------------
Return Address
---------------
old ebp
---------------
local variables
--------------- 

每个块是4个字节还是4个1字节?

------------------
 00 | 40 | 06 | 06
------------------
 ff | ff | de | 70 
------------------

通过gdb我看到为测试分配的缓冲区是0x10

我进入了sssssssss

x/x $rbp = 0xffffde70
x/x $rbp + 8 = 0x00400606
x/s $rbp - 16 = "sssssssss"
x/s $rbp - 8 = "\ns"
x/s $rbp - 4 = ""

那么我输入的字符(十六进制)是如何存储的?喜欢每个街区有多少。这是一个64系统。

 -----------------
 00 | 40 | 06 | 06
------------------
 ff | ff | de | 70 
------------------
    |    |    | 
------------------
    |    |    | s
------------------
 s  | s  | s  | s
------------------
 s  | s  | s  | s 
------------------
c gcc stack-overflow buffer-overflow
1个回答
2
投票

从严格的C角度来看,我们不知道。

标准没有规定这样的事情。该标准甚至没有提到堆栈的概念。从标准的角度来看,代码是在抽象机器上执行的(即没有描述机器是如何做到的。只有机器必须做什么)。

所以如何完成取决于具体的实现,它(可能)因系统而异。

您需要找到您正在使用的系统的ABI文档。 ABI文档将描述如何在您的系统上完成它。

请参阅en.wikipedia.org/wiki/Application_binary_interface

也许读Where is the x86-64 System V ABI documented?

© www.soinside.com 2019 - 2024. All rights reserved.