1

C++ 最終版の戦艦ボード ゲームに基づいてプログラムを作成しています。現在取り組んでいる問題は、ユーザー アカウントの管理方法です。ユーザーがプレイするたびに同じアカウントを使用して、勝敗の記録を追跡できるようにする必要があります。データをファイルに書き込むことはできますが、プレーヤーが再度ログインしたときにそれを読み込んでから、ユーザー名を見つけるために並べ替える必要があります。私はこの部分で立ち往生しています。

これは私が使用しているファイルで、ユーザー名、勝ち、負けとして読み取られます。

Rocky 0 0
Bob 0 0
dave 0 0
Jerry 0 0
Bert 0 0
Ernie 0 0
Marcus 0 0

編集:これは私が何度も繰り返している出力です

-858993460
-858993460

-858993460
-858993460

-858993460
-858993460

UserData は構造体です

//begin create/find account function
userData createAccount(userData ud){

    //local variables
    int playerOption;

    //creates object to open files
    ifstream infile;

    //creates object to open files
    ofstream outfile;

    do {
        cout << "Do you have an existing account?" << endl;
        cout << "" << endl;
        cout << "Enter 1 for yes or 2 for no:" << endl;
        cin >> playerOption;
    }
    while (playerOption >= 3 || playerOption <= 0);



    if (playerOption == 1){
        cout << "Enter user name:" << endl;
        cin >> ud.name;

        //opens file in read mode
        infile.open("userData.dat");

        //tests to make sure the file is open
        if (!infile){
            cout << "File open failure!";
        }


        //creates array of user data
        userData userDataArray [SIZE];

        //reads data from file into array until end of file
        int i=0;
        while(i<SIZE){
            infile >> userDataArray[i].name;
            infile >> userDataArray[i].wins;
            infile >> userDataArray[i].losses;
            i++;
        }

        ///test output
        int j=0;
        while (j<SIZE){
            cout << userDataArray[j].name << endl;
            cout << userDataArray[j].wins << endl;
            cout << userDataArray[j].losses << endl;
            j++;
        }
        //end test output


        //closes file
        infile.close();
    }

    else if(playerOption == 2){
        cout << "Enter user name:" << endl;
        cin >> ud.name;
        ud.wins = 0;
        ud.losses = 0;

        //opens file in write mode
        outfile.open("userData.dat",ios::app);

        //tests to make sure the file is open
        if (!outfile){
            cout << "File open failure!";
        }

        //writes userData struct to file
        outfile << ud.name << " " << ud.wins << " " << ud.losses << endl;

        //closes file
        outfile.close();
    }

    return ud;

//end create/find account function
}
4

1 に答える 1

1

これは最小限の例であり、完全に機能します。

#include <iostream>
#include <fstream>

using namespace std;

typedef struct { string name; int wins; int losses; } userData;

void createAccount(){
    ifstream infile;
    infile.open("userData.dat");

    userData userDataArray[3];

    for(int i = 0; i < 3; ++i){
        infile >> userDataArray[i].name;
        infile >> userDataArray[i].wins;
        infile >> userDataArray[i].losses;
    }

    for(int i = 0; i < 3; ++i){
        cout << userDataArray[i].name << endl;
        cout << userDataArray[i].wins << endl;
        cout << userDataArray[i].losses << endl;
    }
}

int main(){
    createAccount();
}

出力:

Rocky
0
0
Bob
0
0
dave
0
0

したがって、コードが機能するまで、コードを少しずつ単純化する必要があります。または、私のような単純なコードから始めて、必要な機能を実現する方法を構築してください。

最初の質問は「ファイル データを構造体配列に正常に読み取れないのはなぜですか」でしたが、明らかにそれは問題ではありません。

まず、 の値はSIZE何ですか? 出力が非常に長いと言う場合はsize、ファイル内のシリアル化されたデータの数よりもはるかに大きな値に設定されている可能性があり、多くの初期化されていないデータを出力しています。

于 2013-04-22T19:02:28.423 に答える