我知道程序中有一个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;
}
答案 0 :(得分:1)
取消引用空指针。 argv[argc]
被定义为NULL
。
我认为你的意思是func( argv[1] );
。数组在C中从零开始索引。