我想在文件中创建文本,这是我的代码:
int ecrire(){
char buf[1024];
int bytesStored;
int fildes;
char path[128];
int i=0;
mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;
int flags = O_WRONLY;
printf("\n%s-->Donner l'emplacement du fichier :%s ", CYAN_NORMAL, RESETCOLOR);
scanf("%s", path);
fildes = open(path, flags, mode);
if(fildes == -1){
return 0;
}
printf("\n%s-->Enter le contenu pour le fichier%s ", CYAN_NORMAL, RESETCOLOR);
printf("%s(Appuyer CTRl+D a la fin du fichier) :%s \n", CYAN_UNDERLINE , RESETCOLOR);
fflush(stdin);
while((buf[i] = getc(stdin)) != EOF) i++;
buf[i] = '\0';
bytesStored = sizeof(buf);
if(write(fildes,buf,bytesStored) < 0){
return 0;
}
close(fildes);
return 1;
}
例如,如果我写这个内容:
aaaaaaa
jjjjjjjjj
@@@@@@@
当我读到它时,我明白了:
aaaaaaa
jjjjjjjjj
@@@@@@@
P�td�=�=�=�w�wQ�td��}�Ya��E}���P�x�ڿ��ڿAa��*}�P���+}���}�x�ڿ�X�t�ڿp�ڿ���|����#a���Aa���ڿ+}�;0~�E�`��
�
.}�X(}��E}��#a�4C}�x�ڿ��ڿP�D�ڿ�Z���ڿ��}�`�ڿ4C}�h�ڿ�Z.}�\U�
~�x�ڿ��\U�;0~�D�ڿ\U�pS�~�E}�����#a�X(}�p�E}��A~�P�P���a�P�>�}�@���}�� \�P�\r`�+}���}��-}��-}���~���~��D}������F}���h�`���@}�+}�P�I`��M`[~�;H+}�X(}�N��#a� �@{���g�P���ڿ�Z�`�ڿ��}�ڿ ��ڿ�Z�H+}�8Y�}��!�������� J{�����}��fg� J{���ڿ8Y�����I`�N���8����h�`�X(}� J{���g� J{�}�U�g��J{���}�I`��|�sLn�@{�{~g�P�8Y���%~��Z�H+}���g��J{���ڿ�i���ڿ��J{�
为什么我遇到这个问题,我该如何解决呢?
答案 0 :(得分:1)
bytesStored = sizeof(buf);
将bytesStored
设置为1024;和
if(write(fildes,buf,bytesStored) < 0){
只是写道,你知道,所有这一切。因为堆栈中存在buf[]
,所以对其内容没有任何保证,正如您所发现的,它是1024字节的垃圾。
你可能想做strlen(buf)
之类的事情。
答案 1 :(得分:1)
首先这是不好的,因为getc返回一个int,然后你将它存储在char buf [i]中,然后你比较int值EOF。
(buf[i] = getc(stdin)) != EOF
你需要
int c;
while((c = getc(stdin)) != EOF)
buf[i] = c;
其次,你正在填写buf直到你阅读EOF,但是你正在设置bytesStored = sizeof(buf);
并写出完整的缓冲区 - 这在开始时是有效的,但在结束时是未初始化的。因此,您最终会得到一个文件,其中包含有效数据,最后是垃圾。你需要设置
bytesStored = i;
另外,cou可以消除i并直接修改bytesStored。