这个程序在我的 UNIX 机器上导致了一个段错误。我将原因缩小到第二次调用 memset()。
为什么会出现这种行为?第一个“块”代码与第二个几乎相同,不是吗?如果第二个调用 memset segfault,为什么第一次调用没有呢?
我查看了有关 segfaulting memset 调用的其他线程,但没有一个与此类似。
如果您想知道我为什么要编写这样一个微不足道的程序,它改编自我一直在编写的另一个程序,我用它来教自己如何将 memcpy() 应用于结构。
#include <stdio.h>
#include <stdlib.h>
typedef struct{
int x;
char text;
} FilesStruct;
int
main(int argc, char** argv)
{
FilesStruct *old_dir;
memset(old_dir,0,sizeof(FilesStruct));
old_dir->x = 3;
old_dir->text = 'c';
printf("old dir: %d,%c\n",old_dir->x,old_dir->text);
FilesStruct *new_dir;
memset(new_dir,0,sizeof(FilesStruct));
new_dir->x = 7;
new_dir->text = 'g';
printf("new dir: %d,%c\n",new_dir->x,new_dir->text);
return 0;
}