2

たとえば、データを保存する方法がわかりません (学生 ID 、名前、姓) 唯一の学生 ID は整数です。(AddButton) を押したときにこれらのデータをテキスト ファイルに保存してから、これらを更新したいと思います。 (UpdateButton) を押すとデータが保存されますが、保存されたデータがファイルに表示されるたびにベクトル配列が使用され、(UpdateButton) を押してもデータが TextField に返されずに更新されます.

     class BtnListenerAdd implements ActionListener{
      public void actionPerformed(ActionEvent a) {

        if (a.getSource()==btnAdd){
            Student s=new Student(tfname.getText(),tfsurname.getText());
            s.number=Integer.parseInt(tfno.getText());
            myVector.add(s);
               //System.out.println(s);

            try{
                java.io.RandomAccessFile raf =
                               new java.io.RandomAccessFile("e:\\random.txt", "rw");


                    for (int i = 0; i < myVector.size(); i++) {
                      raf.writeChars(myVector.toString());
                    }

                    raf.seek(0);
                    while (raf.getFilePointer() < raf.length()) {
                      System.out.println(raf.readChar());
                    }

                raf.close();
            }catch(Exception e){
                System.out.println( e.toString() );
            }
        }

        if (a.getSource()==btnList){
            ta1.setText("");
            for (Student s : myVector) {
                ta1.append(s.toString()+ "\n"); 
            }
        }           
        }

     }


  class BtnListenerUpdate implements ActionListener{

    public void actionPerformed(ActionEvent s) {

        if (s.getSource()==btnUpdate){
            Student l=new Student(tfname.getText(),tfsurname.getText());
            l.number=Integer.parseInt(tfno.getText());
            myVector.add(l);


            try{
                java.io.RandomAccessFile raf = 
                              new java.io.RandomAccessFile("e:\\random.txt", "rw");

                for(int i=0; i <myVector.size(); i++) {
                    raf.writeChar(myVector.size());
                }

                raf.seek(0);
               int no= raf.readInt();
               tfno.setText(no +  "");
               System.out.println(no);


               String nam = "";
                for(int x=0; x<50; x++){
                    nam += raf.readChar();
                }


                nam = "";
                for(int x=0; x<50; x++){
                    nam += raf.readChar();
                }


            }catch(Exception e){
                System.out.println( e.toString() );
            }
        }

    }


  }
4

2 に答える 2

2

それほど多くのレコードを作成または更新しない場合は、 BufferedWriterを使用することをお勧めします。もしそうなら、MongoMySQLのようなデータベースを使用することをお勧めします

また、UTF-8データを使用してコードのテストを開始することもできます。ウムラウトなど。:)

于 2013-01-13T14:12:49.190 に答える
0

これ以上書く前に、理解できる少量のコードを書くことをお勧めします。これを書くコードが多ければ多いほど、修正が難しいことについて混乱します。

ユニットテストを行う別のクラスの作成を再開します。このクラスは、作成できる最も単純なコードから開始し、これが機能する場合は、もう少し追加してテストします。

残念ながら、あなたが書いたコードのいくつかはナンセンスであり、それが私がそれを再利用しない理由です。

于 2013-01-13T14:25:01.050 に答える