如何检查ifstream是否在C ++中的文件结尾
How to check whether ifstream is end of file in C++
我需要按顺序读取一个大文件(大约 10GB)的所有块,该文件包含许多带有几个字符串的浮点数,如下所示(每个项目由 '\n' 分隔):
6.292611
-1.078219E-266
-2.305673E+065
sod;eiwo
4.899747e-237
1.673940e+089
-4.515213
我每次读取MAX_NUM_PER_FILE
项并处理它们并写入另一个文件,但我不知道ifstream
何时结束。
这是我的代码:
ifstream file_input(path_input); //my file is a text file, but i tried both text and binary mode, both failed.
if(file_input)
{
file_input.seekg(0,file_input.end);
unsigned long long length = file_input.tellg(); //get file size
file_input.seekg(0,file_input.beg);
char * buffer = new char [MAX_NUM_PER_FILE+MAX_NUM_PER_LINE];
int i=1,j;
char c,tmp[3];
while(file_input.tellg()<length)
{
file_input.read(buffer,MAX_NUM_PER_FILE);
j=MAX_NUM_PER_FILE;
while(file_input.get(c)&&c!='\n')
buffer[j++]=c; //get a complete item
//process with buffer...
itoa(i++,tmp,10); //int2char
string out_name="out"+string(tmp)+".txt";
ofstream file_output(out_name);
file_output.write(buffer,j);
file_output.close();
}
file_input.close();
delete[] buffer;
}
我的代码出错了,length
比实际文件大。我试过file_input.good()
或者!file_input.eof()
,都没有用,getline(file_input,s)
很好,但是比read
慢很多,我想要read
,但是我不知道如何检查 ifstream
是否是文件结尾。
我在 WINDOWS 7 中使用 VS2010 进行工作。
我已经搜索过了,但是没有任何答案,How to open a file using ifstream and keep reading it until the end这个link不能回答我的问题
更新,问题已解决
大家好,我想通了,是我的错。 while(file_input.tellg()<length)
和 while(file_input.peek()!=EOF)
都可以正常工作!推荐while(file_input.peek()!=EOF)
。
文件末尾后写入的额外项是上次写入的buffer
中剩余的项。
正确代码如下:
ifstream file_input(path_input);
if(file_input)
{
//file_input.seekg(0,file_input.end);
//unsigned long long length = file_input.tellg(); //get file size
//file_input.seekg(0,file_input.beg);
char * buffer = new char [MAX_NUM_PER_FILE+MAX_NUM_PER_LINE];
int i=1,j;
char c,tmp[3];
while(file_input.peek()!=EOF)
{
memset(buffer,0,sizeof(char)*(MAX_NUM_PER_FILE+MAX_NUM_PER_LINE)); //clear first!
file_input.read(buffer,MAX_NUM_PER_FILE);
j=MAX_NUM_PER_FILE;
while(file_input.get(c)&&c!='\n')
buffer[j++]=c;
itoa(i++,tmp,10);//int2char
string out_name="out"+string(tmp)+".txt";
ofstream file_output(out_name);
file_output.write(buffer,strlen(buffer)); //use the correct buffer size instead of j
file_output.close();
}
file_input.close();
delete[] buffer;
}
while( file_input.peek() != EOF )
{
// code
}
基本上peek()
会阅读下一个char
而不提取它。
因此您可以简单地将其与 EOF
进行比较。
我需要按顺序读取一个大文件(大约 10GB)的所有块,该文件包含许多带有几个字符串的浮点数,如下所示(每个项目由 '\n' 分隔):
6.292611
-1.078219E-266
-2.305673E+065
sod;eiwo
4.899747e-237
1.673940e+089
-4.515213
我每次读取MAX_NUM_PER_FILE
项并处理它们并写入另一个文件,但我不知道ifstream
何时结束。
这是我的代码:
ifstream file_input(path_input); //my file is a text file, but i tried both text and binary mode, both failed.
if(file_input)
{
file_input.seekg(0,file_input.end);
unsigned long long length = file_input.tellg(); //get file size
file_input.seekg(0,file_input.beg);
char * buffer = new char [MAX_NUM_PER_FILE+MAX_NUM_PER_LINE];
int i=1,j;
char c,tmp[3];
while(file_input.tellg()<length)
{
file_input.read(buffer,MAX_NUM_PER_FILE);
j=MAX_NUM_PER_FILE;
while(file_input.get(c)&&c!='\n')
buffer[j++]=c; //get a complete item
//process with buffer...
itoa(i++,tmp,10); //int2char
string out_name="out"+string(tmp)+".txt";
ofstream file_output(out_name);
file_output.write(buffer,j);
file_output.close();
}
file_input.close();
delete[] buffer;
}
我的代码出错了,length
比实际文件大。我试过file_input.good()
或者!file_input.eof()
,都没有用,getline(file_input,s)
很好,但是比read
慢很多,我想要read
,但是我不知道如何检查 ifstream
是否是文件结尾。
我在 WINDOWS 7 中使用 VS2010 进行工作。
我已经搜索过了,但是没有任何答案,How to open a file using ifstream and keep reading it until the end这个link不能回答我的问题
更新,问题已解决
大家好,我想通了,是我的错。 while(file_input.tellg()<length)
和 while(file_input.peek()!=EOF)
都可以正常工作!推荐while(file_input.peek()!=EOF)
。
文件末尾后写入的额外项是上次写入的buffer
中剩余的项。
正确代码如下:
ifstream file_input(path_input);
if(file_input)
{
//file_input.seekg(0,file_input.end);
//unsigned long long length = file_input.tellg(); //get file size
//file_input.seekg(0,file_input.beg);
char * buffer = new char [MAX_NUM_PER_FILE+MAX_NUM_PER_LINE];
int i=1,j;
char c,tmp[3];
while(file_input.peek()!=EOF)
{
memset(buffer,0,sizeof(char)*(MAX_NUM_PER_FILE+MAX_NUM_PER_LINE)); //clear first!
file_input.read(buffer,MAX_NUM_PER_FILE);
j=MAX_NUM_PER_FILE;
while(file_input.get(c)&&c!='\n')
buffer[j++]=c;
itoa(i++,tmp,10);//int2char
string out_name="out"+string(tmp)+".txt";
ofstream file_output(out_name);
file_output.write(buffer,strlen(buffer)); //use the correct buffer size instead of j
file_output.close();
}
file_input.close();
delete[] buffer;
}
while( file_input.peek() != EOF )
{
// code
}
基本上peek()
会阅读下一个char
而不提取它。
因此您可以简单地将其与 EOF
进行比较。