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

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

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

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

Q&A

解決済

2回答

1017閲覧

エラーメッセージ at FullTimeWorker.getSalary(FullTimeWorker.java:10)が表示され、どこが問題なのかわからない

NIKONIKONIKONIK

総合スコア83

Java

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

0グッド

0クリップ

投稿2019/06/22 09:39

試したこと
要素数分入力したのですが、出力時に at FullTimeWorker.getSalary(FullTimeWorker.java:10) が無限に表示され、出力できない。

java

1public class Employee { 2 private String number; //社員番号 3 private String name; //社員名 4 private int salary; //基本給 or 時給 5 Employee(String number,String name,int salary){ 6 this.number = number; 7 this.name = name; 8 this.salary = salary; 9 } 10 String getNumber() { 11 return number; 12 } 13 String getName() { 14 return name; 15 } 16 int getSalary() { 17 return salary; 18 } 19 void printEmployee() { 20 System.out.println("Number : " +number); 21 System.out.println("Name : " + name); 22 } 23}

java

1public class FullTimeWorker extends Employee{ 2 private double overTime; //残業時間 3 private static int baseOverTimePay=2400; //残業時間単位 4 FullTimeWorker(String number, String name, int salary,double overTime) { 5 super(number, name, salary); 6 this.overTime = overTime; 7 } 8 @Override 9 int getSalary() { 10 return getSalary()+(int)(FullTimeWorker.baseOverTimePay * overTime);//基本給に残業代を加えた額を返却 11 } 12 @Override 13 void printEmployee() { 14 super.printEmployee(); 15 System.out.println("Base Salary" + super.getSalary()); 16 System.out.println("Over Time" + overTime); 17 System.out.println("Base Over Time Pay : " + baseOverTimePay); 18 System.out.println("Total Salary : " + this.getSalary()); 19 } 20 21} 22

java

1public class PartTimeWorker extends Employee{ 2 private double workTime; //勤務時間 3 PartTimeWorker(String number, String name, int salary,double workTime) { 4 super(number, name, salary); 5 this.workTime = workTime; 6 } 7 @Override 8 int getSalary(){ 9 return (int)(this.getSalary()*workTime);//給与を小数点以下切り捨てで返却 10 } 11 @Override 12 void printEmployee() { 13 super.printEmployee(); 14 System.out.println("Time Salary : " + super.getSalary()); 15 System.out.println("Work Time : " + workTime); 16 System.out.println("Time Salary : " + this.getSalary()); 17 } 18}

java

1//要素数3のEmployee配列を宣言している。 2//社員の種類、社員番号、社員名等を入力し、社員の種類に応じてFullTimeWorker または PartTimeWorker のインスタンスを生成している。 3//3人分の社員を表示。 4import java.util.Scanner; 5public class Kadai0903 { 6 public static void main(String[] args) { 7 Scanner sc = new Scanner(System.in); 8 9 Employee[] em = new Employee[3]; 10 for(int i=0; i<em.length; i++) { 11 System.out.print("FE:FullTimeWorker PE:PartTimeWorker -->"); 12 String Syurui = sc.next(); 13 if(Syurui.equals("FE")) { 14 System.out.print("Number -->"); 15 String number = sc.next(); 16 System.out.print("Name -->"); 17 String name = sc.next(); 18 System.out.print("Base Salary -->"); 19 int salary = sc.nextInt(); 20 System.out.print("Over Time -->"); 21 double overtime = sc.nextDouble(); 22 em[i] = new FullTimeWorker(number,name,salary,overtime); 23 } 24 else if(Syurui.equals("PE")) { 25 System.out.print("Number -->"); 26 String number = sc.next(); 27 System.out.print("Name -->"); 28 String name = sc.next(); 29 System.out.print("Time Salary -->"); 30 int salary = sc.nextInt(); 31 System.out.print("Work Time -->"); 32 int worktime = sc.nextInt(); 33 em[i] = new PartTimeWorker(number,name,salary,worktime); 34 } 35 } 36 for(int i=0; i<em.length; i++) { 37 System.out.println(); 38 if(em[i] instanceof FullTimeWorker) { 39 ((FullTimeWorker)em[i]).printEmployee(); 40 } 41 else if(em[i] instanceof PartTimeWorker) { 42 ((PartTimeWorker)em[i]).printEmployee(); 43 } 44 } 45 }

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

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

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

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

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

guest

回答2

0

補足

出力時に at FullTimeWorker.getSalary(FullTimeWorker.java:10) が無限に表示され、出力できない

おそらく、ずっと上に

plain

1java.lang.StackOverflowError

という文字列を含む行があるはずです。こういう理由でプログラムが止まりました、というものです。その下に、そこに至るまでに呼び出したメソッドの順番を出力しています。
原因はLouiS0616さんの仰るとおり、getSararyメソッドを無限再帰で呼び出していたためです。

投稿2019/06/22 15:09

swordone

総合スコア20651

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

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

NIKONIKONIKONIK

2019/06/23 03:10

回答ありがとうございます。エラー時 スタックオーバーフローエラー表示されてました。 無限再帰 理解しました。
guest

0

ベストアンサー

getSalaryの中でgetSalaryが呼ばれ、その中でまたgetSalaryが呼ばれ...
延々と続いています。

Employee#getSalaryを呼びたいならsuperを使えば良いですが、
基本給を求めるメソッドは別に用意した方が見通しが良くなるように思います。


FullTimeWorkerのsalaryは基本給なのに対して、
PartTimeWorkerのsalaryは時給なのですね。これはちょっと使い勝手が悪そうです。

投稿2019/06/22 09:41

編集2019/06/22 09:48
LouiS0616

総合スコア35660

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

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

NIKONIKONIKONIK

2019/06/22 09:50

メインメソッドに問題はないということですか?
LouiS0616

2019/06/22 09:54

直接的な原因はgetSalary側です。まずそちらを修正しないといけません。 mainメソッド側でも不要なダウンキャストが使われていたりまずそうな部分はありますが、現状のエラーとは関係ありません。
NIKONIKONIKONIK

2019/06/22 10:09

getSalary側をSuper.getSalaryに変更したら出力されました。
NIKONIKONIKONIK

2019/06/22 10:16

出力結果も全て成功しましたが、 LouiSさんが先ほどコメントで仰っていた 不要なダウンキャストについて詳しく教えてくれるとありがたいです。
NIKONIKONIKONIK

2019/06/22 10:38

FullTimeWorkerのsalaryは基本給なのに対して、 PartTimeWorkerのsalaryは時給なのですね。これはちょっと使い勝手が悪そうです。 僕もそう思いますが、学校から出された問題の仕様です。
LouiS0616

2019/06/22 10:43

mainメソッドの終わりの方の、instanceofに依る分岐は不要です。 ポリモーフィズムのおかげで、単に em[i].printEmployee(); と書けば適切なメソッドが呼ばれます。
NIKONIKONIKONIK

2019/06/22 11:35

なるほどです!ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問