在一定数量的条目之后的垃圾值

Garbage values after a certain amount of entries

本文关键字:之后      更新时间:2023-10-16

我一直在绞尽脑汁地研究我写的这个小程序,只是为了测试一些矩阵补全算法。我相信我可能会溢出缓冲区,但我最好奇的是为什么整个缓冲区会损坏。谢谢你

    MovieRating base[baseNum];
MovieRating test[NUM_RATINGS - baseNum];

//load the base data set
string line ="";
ifstream baseF("assets/u1.base");
ifstream testF("assets/u1.test");
if(baseF.fail()){
    cout << "Unable to open File. Program Terminating..."<<endl;
    return 1;
}
int i = 0;
getline(baseF, line);
while(baseF || i < sizeof(base)){
    base[i] = StringToRating(line);
    i++;
    getline(baseF,line);
}
cout << base[15000].mId << " " << base[15000].uId << " " << base[15000].rating << " " << base[15000].timestamp << endl;
baseF.close();
cout << base[15000].rating << endl;

//load testing dataset
if(testF.fail()){
    cout << "Unable to open File. Program Terminating..."<<endl;
    return 1;
}

i = 0;
getline(testF, line);
while(testF || i < sizeof(test)){
    test[i] = StringToRating(line);
    i++;
    getline(testF,line);
}
testF.close();
cout << base[15000].rating << endl;
GlobalMeanValue(base, test);
return 0;

NUM_RATINGS为100,000,baseNum为80,000

前两个计数的输出是正确的,第三个计数是加载了最近20,000个电影评分后的垃圾值。

再次表示感谢

我差点忘了这是在64位linux系统上

你的问题是双重的,在这一行while(baseF || i < sizeof(base)){:

首先,你的意思是使用&&而不是||,这样一旦输入用完,你就完成了。

第二,sizeof(base)是数组的总大小,而不是元素的个数,sizeof(base) / sizeof(base[0])