2

文本文件包含格式如下的行:

lSdhmhlN   15479   6694.74   O
szUfGnoI   18760   5275.53   n

我逐行读取文件,将其数据放入缓冲区变量中,将这些变量存储在 TopicD 对象中,并将该对象插入二叉搜索树。问题是文件的最后一行被读取了两次,因此创建了两个相同的 TopicD 对象并将其插入到树中。为什么?

这是我的代码:

template<class ItemType>
void read( BinarySearchTree<ItemType> & tree )
{
ifstream read( FILE_NAME.c_str() );

if ( read.fail() )
    die( "Error opening the file." );

string strbuff;
double dubbuff;
int intbuff;
char chbuff;

while ( !read.eof() )
{
    read >> strbuff;
    read >> intbuff;
    read >> dubbuff;
    read >> chbuff;
    TopicD buff( strbuff, dubbuff, intbuff, chbuff );
    tree.add(buff);
}

read.close();
}
4

1 回答 1

3

考虑从那个循环中剪掉一点:

while (read >> strbuff >> intbuff >> dubbuff >> chbuff)
    tree.add(TopicD( strbuff, dubbuff, intbuff, chbuff ));

当你到达EOF时,永远不要依赖它.eof()是真实的。相反,当您在那里尝试再次阅读时,这将是真的。因此,您到达 EOF 后的第一次读取失败,但到那时您已经停止检查错误(顺便说一下,您从未检查过错误),只是盲目地将变量中的所有内容插入到树中。

于 2013-03-18T07:23:38.450 回答