void main()
{
FILE *fp;
char ch,str[1000];
if((fp=fopen("record.txt","r++"))==NULL) /* 若文件无法打开,则返回出错信息*/
{
printf("The file can not be opened.\n");
exit(1); /*退出程序*/
}
while((ch=fgetc(fp))!=EOF) /*检测是否到达文件尾*/
fputc(ch,stdout);
fseek(fp,0,2); /*将文件指针定向到文件尾*/
while(strlen(fgets(str,64,stdin))>0) /*若输入字符长度等于0,退出循环*/
{
fputs(str,fp);
fputs("\n",fp);
}
fseek(fp,0,0); /*将文件指针重定向到文件头*/
fclose(fp);
}
不知道是不是文件指针这部分出了问题,望大虾们指教,先谢谢了!!
----------------解决方案--------------------------------------------------------
r++?fopen中能有这个参数吗?
还有,不知道你为什么多次用fseek,如果想要将数据加到文件末尾用追加方式打开就好了。。。
----------------解决方案--------------------------------------------------------
不好意思,多打了个+号,上面应该是if((fp=fopen("record.txt","r+"))==NULL),就是读写方式。我看书上说追加方式打开后直接把指针指向了文件尾,但我还想程序能显示文件的已有内容,如果用追加方式不是无法显示了吗?
----------------解决方案--------------------------------------------------------
最好读和写分开,不要对同一个文件边读又边写
[此贴子已经被作者于2007-8-15 16:01:53编辑过]
----------------解决方案--------------------------------------------------------
分开要怎么分啊,是读完后用fclose()关了,然后再fopen()打开吗?
----------------解决方案--------------------------------------------------------
分开要怎么分啊,是读完后用fclose()关了,然后再fopen()打开吗?
yes
----------------解决方案--------------------------------------------------------
我去试试哈。
----------------解决方案--------------------------------------------------------
文本编辑程序应该在内存中编辑,你可以在堆中申请一个buffer,用完后再申请一个,等用户写完了选择保存命令时把buffer中的内容一次写入文件。
----------------解决方案--------------------------------------------------------
代码改成这样了:
#include<stdio.h>
#include<stdlib.h>
void main()
{
FILE *fp;
char ch,str[1000];
if((fp=fopen("record.txt","r"))==NULL) /* 若文件无法打开,则返回出错信息*/
{
printf("The file can not be opened.\n");
exit(1); /*退出程序*/
}
while((ch=fgetc(fp))!=EOF) /*检测是否到达文件尾*/
fputc(ch,stdout);
fclose(fp);
if((fp=fopen("record.txt","w"))==NULL)
{
printf("The file can not be opened.\n");
exit(1);
}
while(strlen(fgets(str,64,stdin))>0) /*若输入字符长度等于0,退出循环*/
{
fputs(str,fp);
fputs("\n",fp);
}
fclose(fp);
}
结果我输入一串字符后,按两下回车无法退出。强制关掉TC后打开record.txt文件一看,空白了,我输入的字符串也没写进去…………
ls说的“堆”是数据结构吧?是链表、二叉树什么什么的那些内容吧,我还没学到耶~~~我的那本教程里只介绍了链表~~
----------------解决方案--------------------------------------------------------
你楼上说的堆是一个空间,不是数据结构
----------------解决方案--------------------------------------------------------