저는 자바 학생이며 제 객체 지향적 인 객체를 만들기 위해 노력하고 있습니다. 나는 쉽게 계산기를 주 코드화 할 수 있지만, 나는 그것을 방법으로 구현하는 데 정말로 어려움을 겪고있다. 다음 코드는 항상 0을 반환하지만 목표는 사용자가 한 줄에 연산자와 숫자를 입력 할 수있는 프로그램을 만드는 것입니다 (예 +5). 코드는 이전 값, 새 값 및 재설정 허용. 난 당신의 코드에서 몇 가지 실수가 있습니다calculator.getValue()가 항상 0입니까?
출력
Enter an operator and a number:
+5
0.0
계산기 클래스
import java.util.Scanner;
public class Calculator {
private final int RESET = 0;
private double number = 0;
private double result = 0; // I believe this is the issue but how can I resolve it?
private char operator;
private static Scanner keyboard = new Scanner(System.in);
public Calculator(double number)
{
this.number = number;
}
// this method invokes the whatOperator() to create a new result
// the edited method still returns 0
public double aResult(Calculator other)
{
other.whatOperator();
this.result = other.result;
return result;
}
// I created this method in hopes that it would do most of the work..when I invoke it and enter my operator and number it does not seem to function correctly
public void whatOperator()
{
String operator = null;
operator = enterNumber();
double theNumber = Double.parseDouble(operator);
char theOperator =operator.charAt(0);
operator = null;
operator += theOperator;
// switch method to find the operator
switch(operator){
case "*":
result = getNumber() * theNumber;
break;
case "/":
result = getNumber()/theNumber;
break;
case "+":
result = getNumber() + theNumber;
break;
case "-":
result = getNumber() - theNumber;
break;
case "R":
result = RESET;
break;
}
}
// methods for operation...I was hoping to not use these
public double add(double secondNumber)
{
result = number + secondNumber;
return result;
}
public double divide(double secondNumber)
{
result = number/secondNumber;
return result;
}
public double multiply(double secondNumber)
{
result = number * secondNumber;
return result;
}
public void subtract(double secondNumber)
{
result = number - secondNumber;
}
public double getNumber()
{
return number;
}
// method for getting input
public static String enterNumber()
{
System.out.println("Enter an operator and a number:");
String toString = keyboard.nextLine();
return toString;
}
public static void main (String[] args) {
// the calculator is initialized at 0
Calculator a = new Calculator(0);
// now I create a second calculator with the result from the aResult()
Calculator b = new Calculator(a.aResult(a));
// why is b.getNumber() = 0 at this point?
String theString = String.valueOf(b.getNumber());
// prints 0 every time
System.out.println(theString);
}
}
게시 한 코드에는 getNumber() 메소드가 없습니다. – shmosel
aResult'this.result = result'는 아무 것도하지 않고,'this.result = other.aResult()'를 읽어야합니다. – Turo
일반적으로, 계산의 각 단계마다 새로운 'Calculator'를 만드는 것은 매우 이상합니다. 인스턴스가 하나만 있어야합니다. – shmosel