
C++读取二进制文件问题
ifstreamin;in.open("book.dat",ios_base::in|ios_base::binary);//以二进制方式打开Booktemp;if(!i...
ifstream in;
in.open("book.dat",ios_base::in|ios_base::binary); //以二进制方式打开
Book temp;
if(!in)
{ cout<<"打开失败";exit(1); }
in.read((char*)&temp,sizeof(temp));
if(in.eof())
{
Code=1;
}
else
{
while(!in.eof())
{
in.read((char*)&temp,sizeof(temp));
cout<<temp.Code<<"ddddddd"<<endl;
Code=temp.Code+1;
}
}
我在测试的时候发现每次循环的最后都会重复读取一次temp,这个是什么原应?
测试的结果是1dddddd
2dddddd
3dddddd
3dddddd
最后一行总是重复出现一次。。 展开
in.open("book.dat",ios_base::in|ios_base::binary); //以二进制方式打开
Book temp;
if(!in)
{ cout<<"打开失败";exit(1); }
in.read((char*)&temp,sizeof(temp));
if(in.eof())
{
Code=1;
}
else
{
while(!in.eof())
{
in.read((char*)&temp,sizeof(temp));
cout<<temp.Code<<"ddddddd"<<endl;
Code=temp.Code+1;
}
}
我在测试的时候发现每次循环的最后都会重复读取一次temp,这个是什么原应?
测试的结果是1dddddd
2dddddd
3dddddd
3dddddd
最后一行总是重复出现一次。。 展开
展开全部
c/c++从来是这样,
刚好读到文件尾的时候不会有任何反应
在文件末端再读取一次,
读取失败的情况下in.eof()会返回真,
c的FILE也是同样的情况
你可以这么读
#include
<fstream>
#include
<iostream>
using
namespace
std;
int
main()
{
ifstream
in;
in.open("book.dat",ios_base::in|ios_base::binary);
char
c;
while(1)
{
in
>>
c;
//
读取
if(
in.eof()
)
break;//说明上次读取无效
cout
<<
c;//有效,
}
//
下面这段代码会多输出一次c,
就是因为已经到文件尾了eof也不会返回真
/*while(
!in.eof()
)
{
in
>>
c;
cout
<<
c;
}*/
}
或者这么读
#include
<fstream>
#include
<iostream>
using
namespace
std;
int
main()
{
ifstream
in;
in.open("book.dat",ios_base::in|ios_base::binary);
char
buffer[4];
//
假如二进制文件全是4字节数据;
那么每次读一个4字节块
int
nRead;
while(
nRead
=
in.read(buffer,
sizeof(buffer)).gcount()
)
if(
sizeof(buffer)
!=
nRead
)
{
cout
<<
"incorrect
length"
<<
endl;
break;
}
else
;//
处理
}
刚好读到文件尾的时候不会有任何反应
在文件末端再读取一次,
读取失败的情况下in.eof()会返回真,
c的FILE也是同样的情况
你可以这么读
#include
<fstream>
#include
<iostream>
using
namespace
std;
int
main()
{
ifstream
in;
in.open("book.dat",ios_base::in|ios_base::binary);
char
c;
while(1)
{
in
>>
c;
//
读取
if(
in.eof()
)
break;//说明上次读取无效
cout
<<
c;//有效,
}
//
下面这段代码会多输出一次c,
就是因为已经到文件尾了eof也不会返回真
/*while(
!in.eof()
)
{
in
>>
c;
cout
<<
c;
}*/
}
或者这么读
#include
<fstream>
#include
<iostream>
using
namespace
std;
int
main()
{
ifstream
in;
in.open("book.dat",ios_base::in|ios_base::binary);
char
buffer[4];
//
假如二进制文件全是4字节数据;
那么每次读一个4字节块
int
nRead;
while(
nRead
=
in.read(buffer,
sizeof(buffer)).gcount()
)
if(
sizeof(buffer)
!=
nRead
)
{
cout
<<
"incorrect
length"
<<
endl;
break;
}
else
;//
处理
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
c/c++从来是这样, 刚好读到文件尾的时候不会有任何反应
在文件末端再读取一次, 读取失败的情况下in.eof()会返回真, c的FILE也是同样的情况
你可以这么读
#include <fstream>
#include <iostream>
using namespace std;
int main()
{
ifstream in;
in.open("book.dat",ios_base::in|ios_base::binary);
char c;
while(1)
{
in >> c; // 读取
if( in.eof() )
break;//说明上次读取无效
cout << c;//有效,
}
// 下面这段代码会多输出一次c, 就是因为已经到文件尾了eof也不会返回真
/*while( !in.eof() )
{
in >> c;
cout << c;
}*/
}
或者这么读
#include <fstream>
#include <iostream>
using namespace std;
int main()
{
ifstream in;
in.open("book.dat",ios_base::in|ios_base::binary);
char buffer[4]; // 假如二进制文件全是4字节数据; 那么每次读一个4字节块
int nRead;
while( nRead = in.read(buffer, sizeof(buffer)).gcount() )
if( sizeof(buffer) != nRead )
{
cout << "incorrect length" << endl;
break;
}
else
;// 处理
}
在文件末端再读取一次, 读取失败的情况下in.eof()会返回真, c的FILE也是同样的情况
你可以这么读
#include <fstream>
#include <iostream>
using namespace std;
int main()
{
ifstream in;
in.open("book.dat",ios_base::in|ios_base::binary);
char c;
while(1)
{
in >> c; // 读取
if( in.eof() )
break;//说明上次读取无效
cout << c;//有效,
}
// 下面这段代码会多输出一次c, 就是因为已经到文件尾了eof也不会返回真
/*while( !in.eof() )
{
in >> c;
cout << c;
}*/
}
或者这么读
#include <fstream>
#include <iostream>
using namespace std;
int main()
{
ifstream in;
in.open("book.dat",ios_base::in|ios_base::binary);
char buffer[4]; // 假如二进制文件全是4字节数据; 那么每次读一个4字节块
int nRead;
while( nRead = in.read(buffer, sizeof(buffer)).gcount() )
if( sizeof(buffer) != nRead )
{
cout << "incorrect length" << endl;
break;
}
else
;// 处理
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询