前提・実現したいこと
じゃんけんをするプログラムを書いています.下記のコードはその一部です.
実現したいことは, Janken.javaのstartGameメソッドで, フィールドのMapに保存した
データを, 同クラスのjudgeメソッドで利用することです.
発生している問題・エラーメッセージ
実行すると、こう出ました. Exception in thread "main" java.lang.NullPointerException at Judgeman.judge(Judgeman.java:55) at Main.main(Main.java:22) 55というのはjudgeメソッドのif文、22というのはman.judge()をさしています. judgeメソッド内の最初の出力ではアクセスできているのに(表示されるので) なぜif文に入るとエラーが出るのかが分かりません.
該当のソースコード
java
1//////////////////////////////Main.javaです 2import java.util.*; 3 4public class Main{ 5 public static void main(String[] args){ 6 Scanner sc = new Scanner(System.in); 7 int n = sc.nextInt(); 8 int m = sc.nextInt(); 9 Player[] p = new Player[n]; 10 for(int i = 0; i < n; i++){ 11 p[i] = new Player(i); 12 } 13 14 Judgeman man = new Judgeman(); 15 Counter cnt = new Counter(n, m); 16 17 //試しに一回じゃんけんしてみる//clear 18 man.startGame(p, cnt); 19 //格納された手から、勝ち手を判断できるか試してみる 20 man.judge(); 21 22 } 23} 24/////////////////////////////////////Judgeman.javaです 25import java.util.*; 26 27public class Judgeman{ 28 public final int ROCK = 0; 29 public final int PAPER = 1; 30 public final int SCISSORS = 2; 31 public final int TIE = -1; 32 33 Map<Integer, Integer> map = new LinkedHashMap<>(); 34 35 36 public void startGame(Player[] p, Counter cnt){ 37 for(Player player : p){ 38 int result = player.showHand(); 39 this.map.put(result, this.map.getOrDefault(result, 0) + 1); 40 //System.out.println("キー" + result + "の値は" + this.map.get(result)); 41 } 42 } 43 44 public int judge(){ 45 46 System.out.println("キー0" + "の値は" + this.map.get(0));//これは表示される 47 if((this.map.get(ROCK)>=1 && this.map.get(PAPER)>=1 && this.map.get(SCISSORS)>=1) || 48 (this.map.get(ROCK)>=1 && this.map.get(PAPER)==0 && this.map.get(SCISSORS)==0) || 49 (this.map.get(ROCK)==0 && this.map.get(PAPER)>=1 && this.map.get(SCISSORS)==0) || 50 (this.map.get(ROCK)==0 && this.map.get(PAPER)==0 && this.map.get(SCISSORS)>=1)){ 51 return TIE; 52 }else{ 53 if((map.get(ROCK)>=1 && map.get(PAPER)>=1 && map.get(SCISSORS)==0)){ 54 return PAPER; 55 } 56 if((map.get(ROCK)==0 && map.get(PAPER)>=1 && map.get(SCISSORS)>=1)){ 57 return SCISSORS; 58 } 59 if((map.get(ROCK)>=1 && map.get(PAPER)==0 && map.get(SCISSORS)>=1)){ 60 return ROCK; 61 } 62 } 63 return 100; 64 } 65} 66
補足情報(FW/ツールのバージョンなど)
java 10.0.2 2018-07-17
Java(TM) SE Runtime Environment 18.3 (build 10.0.2+13)
Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10.0.2+13, mixed mode)
再現がめんどくさいのでPlayerクラスも貼りつけてほしいな~というところですね( )
他の方の回答で解決致しましたので補足はしませんが, 次回から貼るようにします... Counterクラスはともかく, 呼び出し先のメソッドでガンガン使っているPlayerクラスは貼るべきでした. 配慮が足りず申し訳ありません.
回答1件
あなたの回答
tips
プレビュー