質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

3回答

7204閲覧

ArrayListの要素をremoveを用いて削除。よろしく御願い致します。

akagami_bb

総合スコア19

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2016/02/17 17:41

編集2016/02/17 17:55

お世話になっております。
現在私はテキストファイルの入出力について勉強しております。
ある程度は完成したのですが、最後に入力された数値に応じて、listに追加されているデータを削除したいのですが、どうしてもエラーが出てしまい削除が出来ません。3日ほど自分なりに考えているのですが、どうしても分かりませんでした・・・。
エラー箇所は下から10行目あたりでコメントつけておきました。

どなたかお力をお貸し下さい。よろしく御願い致します。
//エラー内容
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 0, Size: 0
at java.util.ArrayList.rangeCheck(ArrayList.java:653)
at java.util.ArrayList.remove(ArrayList.java:492)
at Text.main(Text.java:147)

import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; public class Text { // 1人分のデータを格納するクラス class Person { private String name; private String address; private String tel; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } public String getTel() { return tel; } public void setTel(String tel) { this.tel = tel; } } private boolean checkBeforeReadFile(File file) { if (file.exists()) { if (file.isFile() && file.canRead()) { return true; } } return false; } // ファイルを読み込む public ArrayList<Person> readFile(File file) { int i = 0; ArrayList<Person> list = new ArrayList<Person>(); BufferedReader br = null; try { if (checkBeforeReadFile(file)) { br = new BufferedReader(new FileReader(file)); String line = null; Person person = null; while ((line = br.readLine()) != null) { switch (i) { case 0: // Person クラスのインスタンスを生成 person = new Person(); // 名前を格納 person.setName(line); // 次は i = 1 → 住所 i++; break; case 1: person.setAddress(line); i++; break; case 2: person.setTel(line); // 1人分のデータの格納が完了したので、リストに追加 list.add(person); i = 0; break; } } } } catch (IOException e) { e.printStackTrace(); } finally { if (br != null) { try { br.close(); } catch (IOException e) { e.printStackTrace(); } } } return list; } // 全員分のデータを表示する void showPeople(ArrayList<Person> list) { int j=0; for (Person person : list) { System.out.println("<No." + j + ">"); System.out.println("名前:" + person.getName()); System.out.println("住所:" + person.getAddress()); System.out.println("電話番号:" + person.getTel()); j++; } } //コンソール制御 public static void main(String[] args) { File file = new File("C:\\pleiades\\workspace\\JavaTest\\src\\test.txt"); Text text = new Text(); ArrayList<Person> list = text.readFile(file); text.showPeople(list); System.out.println("0:新規登録 1:削除"); int input = new java.util.Scanner(System.in).nextInt(); try{ if(input == 0){ PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(file,true))); BufferedReader br = new BufferedReader(new FileReader(file)); System.out.println("名前を入力してください"); String name = new java.util.Scanner(System.in).nextLine(); System.out.println("住所を入力してください"); String address = new java.util.Scanner(System.in).nextLine(); System.out.println("電話番号を入力してください"); String tel = new java.util.Scanner(System.in).nextLine(); pw.println(name); pw.println(address); pw.println(tel); pw.close(); System.out.println("連絡先を追加しました"); } } catch (IOException ex) { System.out.println("err"); } if(input == 1){ System.out.println("削除するデータを選んでください"); int n = new java.util.Scanner(System.in).nextInt(); for(int i=0; i<3; i++){ //ここでエラーが起き、削除が出来ない list.remove(n*3); } System.out.println("<No." + (n) + ">のデータを削除しました"); try{ PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(file))); for(Person result : list){ pw.println(result); } pw.close(); } catch (IOException ex) { System.out.println("err"); } } } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

issei.

2016/02/17 17:50 編集

ソースコードをコードタグで囲って下さい。それと、可能であればエラーのスタックトレースを貼って下さい(仮説の裏付けとして欲しいです)。
akagami_bb

2016/02/17 17:49

申し訳ございません。この機能を知りませんでした。ご指摘ありがとうございました。
issei.

2016/02/17 17:50

ありがとうございます!
coco_bauer

2016/02/17 21:42

古いコード(一人分のデータを配列の連続した3要素(テキストファイルの3行)を使って保持する方式)と、新しいコード(一人分のデータを1つのclass Personのオブジェクトに保持する)が混ざっていませんか? 一人分のデータを削除するならlistから1項目(一人分)をremoveすれば良いのに、forループでremoveを3回繰り返しているのは、古いコードで3項目(名前、住所、電話番号)を順に削除していた名残のような気がします。
akagami_bb

2016/02/18 06:21

ご回答ありがとうございます。 おっしゃるとおりで、編集しなおしたところ、上手く削除することが出来ました!また機会がありましたらよろしく御願い致します。
guest

回答3

0

ベストアンサー

java

1 System.out.println("削除するデータを選んでください"); 2 int n = new java.util.Scanner(System.in).nextInt(); 3 for(int i=0; i<3; i++){ 4//ここでエラーが起き、削除が出来ない 5 list.remove(n*3); 6 }

java

1 System.out.println("削除するデータを選んでください"); 2 int n = new java.util.Scanner(System.in).nextInt(); 3 if( n >= 0 && n < list.size()){ 4 list.remove(n); // n番目の要素を削除 5 }else{ 6 System.out.println("番号が範囲外です"); 7 }

現在環境が無いのでテストしていませんが、こんな感じになると思います。

投稿2016/02/17 21:40

編集2016/02/17 22:17
cateye

総合スコア6851

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akagami_bb

2016/02/18 06:19

ご回答ありがとうございます。 上記の内容を編集して使用したところ、上手く削除をすることが出来ました。 今回はありがとうございました!また機会がありましたらよろしく御願いいたします。
guest

0

何のエラーが出ているか分かりませんが、大方IndexOutOfBoundsExceptionではないですか?
remove(int)はArrayListの、引数の位置にある要素を削除するもので、引数が負またはArrayListのサイズ以上のとき例外になります。

投稿2016/02/17 17:55

swordone

総合スコア20651

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akagami_bb

2016/02/18 06:18

ご回答ありがとうございます。 エラー時に隣に数字がでるので、変更したところ上手く削除がいきました。 わざわざありがとうございました!
guest

0

読みやすさなどを一端置いておいて、こうすれば動くように思います(ごめんなさい検証環境用意できてません)

  • 変更前

Java

1for(int i=0; i<3; i++){ 2//ここでエラーが起き、削除が出来ない 3 list.remove(n*3); 4}
  • 変更後

Java

1 list.removeRange(n*3, n*3 + 2);

投稿2016/02/17 17:55

issei.

総合スコア326

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akagami_bb

2016/02/17 17:59

ご回答ありがとうございます。 しかし、「メソッド removeRange(int, int) は型 ArrayList<Text.Person> で不可視です」 と出てエラーになってしまいました。私のソースコードが悪いのだと思いますが、わざわざ回答してくださったのに申し訳ないです。
swordone

2016/02/17 23:23

それはコードが悪いわけではなさそうです。 removeRangeはprotectedメソッドなので、「同クラス内、同一パッケージ内、またはサブクラス内」でのみ使用可能です。 この箇所はいずれにも該当しないのでそもそも使えないのです。 これを使いたいのなら、このメソッドをオーバーライドしておく必要があるでしょう。
akagami_bb

2016/02/18 06:17

ご回答ありがとうございます。 また一つ勉強になりました。これから使用するときは気をつけたいと思います。
issei.

2016/02/18 08:03

protectedでしたか、失礼しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問