strcpy的分段错误(ELF可执行文件)

时间:2014-10-06 00:49:40

标签: c gcc

我知道程序中有一个BoF,但缓冲区没有超出" AA",那么,为什么我得到"分段错误"?...

$ gcc program.c -o program
$ ./program AA
Segmentation fault

这是来源:

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

void func(char *arg)
{
    char name[32];
    strcpy(name, arg);
    printf("\nWelcome, %s\n\n", name);
}

int main(int argc, char *argv[])
{
    if (argc != 2)
    {
        printf("Use: %s YOUR_NAME\n", argv[0]);
        exit(0);
    }

    func(argv[2]);
    printf("The end\n\n");

    return 0;
}

1 个答案:

答案 0 :(得分:1)

取消引用空指针。 argv[argc]被定义为NULL

我认为你的意思是func( argv[1] );。数组在C中从零开始索引。