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

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

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

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

Q&A

解決済

1回答

905閲覧

どう直せば良いのか分からなくなってしまいました。

shuuji

総合スコア11

Java

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

0グッド

0クリップ

投稿2017/11/22 14:49

編集2017/11/22 16:21

###前提・実現したいこと
初心者なので、まだ理解していないところもあり説明が分かりづらい部分もあるかと思いますがご了承ください。
「スッキリわかるJava入門」を読み、Dokojavaを使いながら書いています。
あるクラスが書かれているページがあり、それを実現させるためにどうすればよいのかを考えて自分で他のクラスも書いて正常に動作できるように書いていましたが、どうしても
エラーの原因が分かりません。
ご指導のほうよろしくお願いします。
以下は元のコードです
(Hero.java)

public class Hero { private String name = "ミナト"; private int hp = 100; private void attack(Matango m){ System.out.println(this.name + "の攻撃!"); m.hp -= 5; System.out.println("5ポイントのダメージ!"); } public void run(){ System.out.println(this.name + "は逃げ出した!"); } }

###発生している問題・エラーメッセージ
上のコードに対してメインクラスと敵クラスを付けたし、private設定されているのでゲッター、セッターを使いながら正常に動作するのをめざし書いていたのですが、以下のエラーがずっと解決できません。

互換性のない型 期待値: java.lang.String 検出値: void Hero.java(17行目)

###該当のソースコード
<Main.java>

public class Main { public static void main(String[] args){ Hero h = new Hero(); Matango m = new Matango(); System.out.println(m.getName() + "が現れた!"); System.out.println("HP:" + m.getHp()); System.out.println(h.getName() + "は戦うことにした!"); System.out.println("HP:" + h.getHp()); h.getAttack(m); h.run(); } }

<Hero.java>

public class Hero { private String name = "ミナト"; public String getName(){return this.name;} public void setName(String name){this.name = name;} private int hp = 100; public int getHp(){return this.hp;} public void setHp(int hp){this.hp = hp;} private void attack(Matango m){ System.out.println(this.name + "の攻撃!"); System.out.println("切りつける!"); m.getHp(); System.out.println(m.getName() + "に5ポイントのダメージ!"); System.out.println("HP:" + m.getHp()); } public String getAttack(Matango m){return this.attack(m);} public void run(){ System.out.println(this.name + "は逃げ出した!"); System.out.println("HP:" + this.hp); } }

<Matango.java>

public class Matango { private String name = "お化けキノコ"; public String getName(){return this.name;} public void setName(String name){this.name = name;} private int hp = 30; public int getHp(){return this.hp;} public void setHp(int hp){this.hp = hp;} }

###試したこと
Heroクラスのどこかを直さないといけないのかなんなのか分からなくなってしまいました。
###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

guest

回答1

0

ベストアンサー

attackの戻り値がないのに、getAttackでそれを返そうとしているからです。

Java

1private void attack(Matango m){ 2 System.out.println(this.name + "の攻撃!"); 3 System.out.println("切りつける!"); 4 m.getHp(); // ← これも不要 5 System.out.println(m.getName() + "に5ポイントのダメージ!"); 6 System.out.println("HP:" + m.getHp()); 7}

...

public String getAttack(Matango m){return this.attack(m);}


ゲッターを積極的に使おうとすることは良いことですが、少し履き違えている気がします。
ゲッターでゲットするのは変数であって、単にメソッドを呼び出すときにはそのままでよいのです。

getAttackというメソッドは不要です。外部からattackを直接呼び出して良いでしょう。
その場合、attackのアクセス修飾子をprivateでなくす必要はありますが。

ついでに

ちょっと気になったことを。

  • setterは出来るだけ作らない

アクセッサはアクセスを必要最低限に制限するためにあるので、出来るだけ絞った方が良いです。

ゲッターセッター
外部から参照されないxx
外部から参照されるox
外部から変更される必要があるoo
  • 必要に応じて抽象的なクラスを導入する

まだクラスの継承について学習していないのかもしれませんが。
現状勇者がマタンゴ以外と戦えないので、Monsterクラスがあるといいですね。

質問の仕方について

teratailには、上記のようにコードを見やすく表示する機能があります。
質問編集画面を開き、コードを選択した状態で<code>ボタンを押してください。

投稿2017/11/22 14:54

編集2017/11/22 15:06
LouiS0616

総合スコア35660

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

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

shuuji

2017/11/22 16:38

回答ありがとうございます!とても勉強になります。 無事に作動させることが出来ました^^ <code>ボタンもさっそく使って修正しました。 習ったことを手当たり次第試そうとしてしまいますね汗。
LouiS0616

2017/11/22 16:42

質問編集の対応感謝します。 いろいろな機能やノウハウを試してみるのは良いことだと思いますよ。 なぜそのような書き方が必要なのか?というところまで理解していたら◎です。
shuuji

2017/11/22 16:54

もう一つよろしいでしょうか? 無事に作動したと思ったらお化けキノコのHPが減っていませんでした。attackはpublicにしてありますが、Matangoはprivateなのでこれはゲッターを利用して呼び出そうとし m.getHp() -= 5; と書いてみましたがエラーメッセージで ”クラス Matangoのメソッド getHpは指定された型に適用できません。 期待値: 引数がありません 検出値: int 理由: 実引数リストと仮引数リストの長さが異なります” とでてしまいました。変数を呼出し、その値を変更するにはどうすれば良いでしょうか?そもそも可能でしょうか?
LouiS0616

2017/11/22 16:58

getHp()によって返ってくるのはただの数値です。 ですので、HPが30の場合、m.getHp() -= 5;は30 -= 5;と同じなのでコンパイルエラーになります。 m.setHp(m.getHp() - 5); と書く必要がありますね。
LouiS0616

2017/11/22 17:00

ただし、やはり外部からセッターを使うのは出来るだけ避けたいです。 マタンゴにdamagedメソッドを作った方が綺麗かと思いますよ。 public void damaged(int damage) { this.setHp(this.getHp() - damage); }
LouiS0616

2017/11/22 17:01

セッターはよほど必要性がない限り使わないと思っていいです。
shuuji

2017/11/22 17:07

丁寧な解説ありがとうございます! セッターについては参考にしている書籍でもゲッターと比べて説明がサラッとしていてあまり理解できてませんでした。damagedメソッドのバージョンでも試してみたいと思います! ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問