gpt4 book ai didi

C 复制到两个缓冲区中,尽管应该只填充一个缓冲区

转载 作者:太空宇宙 更新时间:2023-11-04 05:24:34 24 4
gpt4 key购买 nike

我用 C 写了一些代码,应该 strcpy 一些输入数据到声明的缓冲区。这是代码:

#include <stdio.h>
#include <string.h>

void function(char *args) {
char buff_1[12];
char buff_2[3] = "ABC";

strcpy(buff_1, args);
printf("buff_1: %s \n", buff_1);
printf("buff_2: %s \n", buff_2);
}

int main(int argc, char *argv[]) {
printf("Input: ");

if(argc > 1)
function(argv[1]);

return 0;
}

如果我现在运行二进制文件,我会假设超过 11 个输入参数的所有内容都会导致缓冲区溢出,但实际上它会将我的输入附加到两个缓冲区:

./main (perl -e 'print "A"x15')
buff_1: AAAAAAAAAAAAAAA
buff_2 :ABCAAAAAAAAAAAAAAA

同时使用 gdb 检查变量显示我的输入参数存储在两个缓冲区中:

(gdb) x/1s buff_1
0xffffd284: 'A' <repeats 11 times>
(gdb) x/1s buff_2
0xffffd281: "ABC", 'A' <repeats 11 times>

我使用以下命令编译代码:gcc -m32 -O0 -g -fno-stack-protector -o main main.c 使用 gcc (Ubuntu 5.2.1-22ubuntu2 )

谁能解释一下这是怎么可能的?

最佳答案

您没有足够的空间用于 buff_2 的空终止。所以 printf("buff_2: %s\n", buff_2); 会溢出你的缓冲区,导致未定义的行为

char buff_2[3] = "ABC"; // Not enough space for \0 
char buff_2[4] = "ABC"; // OK
char buff_2[] = "ABC"; // OK, Size will be 4

关于C 复制到两个缓冲区中,尽管应该只填充一个缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36866476/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com