Сохранение связанного списка в файл (элементы неверны) - PullRequest
0 голосов
/ 14 марта 2012

Мне нужно сохранить связанный список, который я создал, в файл, но я хочу, чтобы каждая часть учетной записи пользователя была его собственным элементом.т.е. (имя пользователя, пароль, адрес электронной почты, имя, порода, пол, возраст, состояние, хобби).Что-то не так с моим кодом, однако, и каждая учетная запись является своим собственным элементом.Любая помощь будет отличной!

Также здесь есть ссылка на мой класс учетной записи, который используется для создания связанного списка http://pastebin.com/jnBrcnP1

Связанный список выглядит следующим образом:

tobi
tobi123
tobi@hotmail.com
tobi
Mixed Breed
Male
1-2
Virginia
Walking
peppy
peppy123
peppy@hotmail.com
peppy
Chihuahua
Male
5-6
Virginia
Eating

Сохраняет в файл следующим образом:

tobitobi123tobi@hotmail.comtobiMixed BreedMale1-2VirginiaWalking
peppypeppy123peppy@hotmail.compeppyChihuahuaMale5-6VirginiaEating

Код для создания связанного списка:

import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.LinkedList;
public class Main extends javax.swing.JFrame implements ActionListener{

public static String readLine(BufferedReader br) throws IOException {
    String rl = br.readLine();
    if (rl.trim().length() > 2){
        return rl;
    }else return readLine(br);
}

public static void main(String[] args) {

    LinkedList<Account> account = new LinkedList<Account>();

    try
    {
        read(account, "output.txt");
    } catch (Exception e)
    {
        System.err.println(e.toString());
    }
        display(account);
    }

    public static void read(LinkedList<Account> account, String inputFileName) throws java.io.IOException
    {
        BufferedReader infile = new BufferedReader(new FileReader(inputFileName));
        while(infile.ready())
        {

            String username = readLine(infile);
            String password = readLine(infile);
            String email = readLine(infile);
            String name = readLine(infile);
            String breed = readLine(infile);
            String gender = readLine(infile);
            String age = readLine(infile);
            String state = readLine(infile);
            String hobby = readLine(infile);

            Account a = new Account(username, password, email, name, breed, gender, age, state, hobby);
            account.add(a);
            a.showList();
        }
        infile.close();
    }

    public static void display(LinkedList<?> c)
    {
        for (Object e : c)
        {
            System.out.println(e);
        }
    }

Код для сохранения связанного списка в файл:

        String file_name = "output.txt";
        try {

                FileWriter fstream = new FileWriter(file_name);
                BufferedWriter out = new BufferedWriter(fstream);

                ListIterator itr = account.listIterator();
                while (itr.hasNext()) {
                    Account element = (Account) itr.next();
                    out.write("" + element);
                    out.newLine();
                }

                out.close();
                System.out.println("File created successfully.");

        } catch (Exception e) {
        }

1 Ответ

1 голос
/ 14 марта 2012

Это проблема, в Account:

public String toString() {
    return ""+username+"\n"+password+"\n"+email+"\n"+name+
           "\n"+breed+"\n"+gender+"\n"+age+"\n"+state+"\n"+hobby;
}

Вы предполагая , что \n является подходящим окончанием строки.Я предполагаю, что вы работаете в Windows, где это будет \r\n.Лично я думаю, что для вашего "написания" кода было бы лучше вообще не использовать toString(), а писать сами строки - в конце концов, он знает формат, который хочет использовать.

(Кроме того, я бы рекомендовал бы использовать "" + ... в качестве способа преобразования значения в строку ...)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...