[英]Confusing output with respect to addresses when passing object by reference in C++
[英]Odd output when passing file stream by reference
在下面的代碼中,我需要從數據文件中讀取以下內容:
Dean DeFino 88 98 99
Sally Johnson 78 89 82
Bill Benny 75 79 81
Thomas Billows 78 84 89
但是,我得到以下輸出:
Dean DeFino 88 98 99
hnson 78 89 82-1850860984 32742
0 0 28
0-413051128 48
-1608528832 32767-415228472
0 -49089-1024065536 6406657
-512190696 48 18048
32767 0 0
0-1850766544 32742-520043854
0 48-517861416 48
-1608527569 32767-520043904
0 32767-520041858 48
-1564475392 -49089 0
48-1850766544 32742
-514484708 48 26100
0-1608527632 32767
`-1608528304 32767-310120049
0 48 0 0
-1608527592 32767-1608527584
48-520056170 48
`-1850862392 32742-1608528432
32742 479434334 0
7491161 0 30
a 0-1608528048 32767
H<@0-1024065536 6406657-1398731262
f 673193995 5371330921477443664
DB( 0 0-1850860160
48-515832000 48
0 2027 1-520053849
0 32742-1608527968 32767
-1850860160 32742 479434334
0-1850860160 32742
6 0-1850860928
48 6 0
[-310357908 48 0
48-520056170 48
-310356040 48-1608527984
32742 725871085 0
11341735 0 45
0 0-1608527600 32767
H<@0-310281904 48-1850766920
32767-1850767776 32742
0 0-1850860808
0-515832000 48
@@ 786 1 0
48-1608527520 32767
-1850860808 32742 725871085
0-1850860808 32742
1 32767-517860984
0 1-310305400 48
看來只有第一行和一半被正確讀取。 給定下面的代碼,我看不出問題出在哪里。 有什么想法嗎?
#include <fstream>
#include <iostream>
#include <iomanip>
using namespace std;
const int NAMESIZE = 15;
const int MAXRECORDS = 50;
struct Grades
{
char name[NAMESIZE + 1];
int test1;
int test2;
int final;
};
typedef Grades gradeType[MAXRECORDS];
void readIt(ifstream&, gradeType, const int);
int main()
{
ifstream indata;
indata.open("graderoll.dat");
gradeType studentRecord;
if (!indata)
{
cout << "Error opening file. \n";
cout << "It may not exist where indicated" << endl;
return 1;
}
readIt(indata, studentRecord, MAXRECORDS);
for (int count = 0; count < MAXRECORDS; count++)
{
cout << studentRecord[count].name << setw(10)
<< studentRecord[count].test1
<< setw(10) << studentRecord[count].test2;
cout << setw(10) << studentRecord[count].final << endl;
}
indata.close();
return 0;
}
void readIt(ifstream& inData, gradeType gradeRec, const int max)
{
int total = 0;
inData.get(gradeRec[total].name, NAMESIZE);
while (inData)
{
inData >> gradeRec[total].test1;
inData >> gradeRec[total].test2;
inData >> gradeRec[total].final;
total++; // add one to total
if (!inData.eof())
inData.get(gradeRec[total].name, NAMESIZE);
}
}
謝謝!
發生問題是因為while
循環正在尋找整數,並且遇到第二個名稱(不是整數)。
更好的方法是將整個行作為字符串讀取,然后使用std::istringstream
從字符串中獲取名稱和測試值。
讀取while
循環時,沒有代碼消耗行尾,因此一個程序遇到行尾,它跳過了文件的其余部分,循環終止。 屏幕上奇怪的輸出是輸出49個垃圾值的空數組的結果(因為MAXRECORDS = 50
)。 創建一個名為numRead
或類似名稱的變量,並將其設置為等於您要讀取的行數。 將其作為結束條件放入for
循環中。 然后在while
循環中,放置inData.ignore(NUMSIZE,'\\ n'); 在讀取名稱之前。 所以:
while (inData)
{
inData >> gradeRec[total].test1;
inData >> gradeRec[total].test2;
inData >> gradeRec[total].final;
total++; // add one to total
inData.ignore(NUMSIZE, '\n');
inData.get(gradeRec[total].name, NAMESIZE);
}
inData.ignore(NUMSIZE,'\\ n'); 會有效地告訴程序忽略接下來的15個字符,或者直到遇到換行符轉義序列為止。 這樣可以正確讀取文件。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.