【发布时间】:2015-10-28 01:40:52
【问题描述】:
我有点像这个人(coava)发布的类似问题。
(Append Random Text without Repetition for File (C))
总结:基本上我正在尝试创建文件,将随机单词附加到其中并将文件存储到目录中
我已经尝试了给出的解决方案,但它对我不起作用,可能是因为在我的情况下,我也将这些文件存储在目录中。
所以我的代码(编辑:这是我的一段代码)看起来像这样:
char *room[4];
room[0] = "okay";
room[1] = "sure";
room[2] = "fine";
room[3] = "noo";
int pid = getpid();
char dirname[30]
sprintf(dirname,"rooms.%d",(int)getpid());
mkdir(dirname,0777);
int bufSize=128;
char *current = malloc(bufSize);
int nroom = sizeof(room) - 1;
int count;
for (count=0;count<3;count++) {
int ipick = rand()%nroom;
int *pick = room[ipick];
room[nroom] = room [--nroom];
snprintf(currentFile,bufSize,"file-%d.txt",count);
FILE *f = fopen(currentFile,"w")
fprintf(f, "YOUR ROOM: %s\n",pick);
fclose(f);
}
然后我得到一个seg.fault,我尝试修改
snprintf(currentFile,bufSize,"file-%d.txt",count);
进入
snprintf(currentFile,bufSize,"file-%d.txt",dirname,count);
它没有给出 seg.fault,但它只是在目录外打印,并在每个文件的内部添加有时我会得到随机值,例如
“连接主机:@blablabla”或一些垃圾符号。
我的 for 循环有问题吗?还是在别的地方?
【问题讨论】:
-
所以我的代码看起来很像这样是没有意义的。如果您需要帮助找出它为什么不起作用,请发布您的实际代码。发布like it 意味着您可以在编写代码时引入新错误(或忽略真实错误)。将实际代码的相关部分复制/粘贴到问题中。
-
@KenWhite 那是我的真实代码....
-
'int nroom = sizeof(room) - 1;' - 看起来不太好:(
-
您可能需要:
snprintf(currentFile, bufSize, "%s/file-%d.txt", dirname, count);— 您忘记输入转换规范来处理目录名称。您还需要添加所有编译器警告(gcc -Wall至少;gcc -Wall -Wextra -Werror -Wmissing-prototypes -Wstrict-prototypes与我使用的接近(我也使用其他一些更深奥的标志)。 -
它是四个指针的大小,以字节为单位,减去 1。所以,在普通系统上,它将是 15 或 31。