读写大文件

liaomingxue 2004-05-05 04:03:27
环境:DOS, BC or TC
问题:读取文件的时候,如果文件太大,那么程序就会不正常退出,没有什么提示信息,仅仅只有:program abnormally terminated. 经过反复测试,当文件大小>=34309bytes时候(占用空间恰好为40KB),程序就会不正常退出,否则就可以正常读取。

请问是什么原因?编译器模式?还是DOS缓冲区大小限制?怎么解决?
...全文
65 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
gzlucky 2004-05-05
  • 打赏
  • 举报
回复
stamp[16]='\0';

字符越界了。
cngdzhang 2004-05-05
  • 打赏
  • 举报
回复
我找到你的程序的问题所在了:)

就是

charRead=fgetc(file);
if(charRead==EOF) break;

因为你的程序刚好读到那个地方的字符恰好是EOF,EOF的值是-1
所以程序没读完文件就退出了

解决办法:

charRead=fgetc(file);
if(charRead==EOF) break;
改为:
charRead=fgetc(file);
if(feof(file)) break;

另外
charRead最好声明为
char charRead;
文件打开方式为
"rb"


liaomingxue 2004-05-05
  • 打赏
  • 举报
回复
ok, you are right.
I use the count variable, which type is INT, to record how many bytes read. So when the file size is greater than MAX_INT, maybe the array will overflow(minus index).Now I changed its type to LONG. OK,it works now.

Thank you very much.
liaomingxue 2004-05-05
  • 打赏
  • 举报
回复
const char paddings[]="0123456789abcdef";
liaomingxue 2004-05-05
  • 打赏
  • 举报
回复
OK, 下面是源代码的一部分
/*
filePath: the absolute path of file which is to add stamp
stamp: the file's stamp which length is 16
*/
void getStamp(char* filePath,char* stamp)
{
FILE* file;
int count=0,charRead;

file=fopen(filePath,"rt");

for(;;)
{
charRead=fgetc(file);
if(charRead==EOF) break;
if(count<16) stamp[count]=charRead;
else stamp[count%16]^=charRead;
count++;
}
while(count<16) {stamp[count]=paddings[count];count++;}
while(count%16 != 0) {stamp[count%16]^=paddings[count%16];count++;}
stamp[16]='\0';
fclose(file);
}
backspray 2004-05-05
  • 打赏
  • 举报
回复
这个不可能....我就调用过1MB大的文件...没有出事过...
而且 从理论上这个也不成立..因为..每读一个字符..只是指针向后移..
再读入再后移...
而读入的字符没有入栈..就不可能溢出...
能把你的代码发一下..研究一下...吗?
cngdzhang 2004-05-05
  • 打赏
  • 举报
回复
是你的数组越界了吧?
纯c读写ini配置文件 用c/c++读写ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini读写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux。

70,023

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧