println与println的Void方法,带返回方法

时间:2015-08-04 16:01:06

标签: java methods return

在我写一个计算器应用程序时,我无法弄清楚最好的方法是:

private void calculate(String command) {
    System.out.print("value1: ");
    int value1 = reader.readInteger();
    System.out.print("value2: ");
    int value2 = reader.readInteger();

    if (command.equals("sum"))
        System.out.println("sum of the values " + sum(value1 + value2));
}

private int sum(int value1, int value2) {
    return value1 + value2;
}

private void calculate(String command) {
    System.out.print("value1: ");
    int value1 = reader.readInteger();
    System.out.print("value2: ");
    int value2 = reader.readInteger();

    if (command.equals("sum"))
        sum();
}

private void sum(int value1, int value2) {
    System.out.println("sum of the values " + value1 + value2);
}

第二个方法使calculate()方法更清晰,但通常首选使用返回方法或void(仅用于打印行)?

3 个答案:

答案 0 :(得分:5)

一般来说,返回值更好 - 然后您可以测试您的方法并在更复杂的计算中重复使用它。

其中一个好方法是定义一些计算和返回值的calculate方法,并定义void show方法,该方法将接受作为参数值显示在屏幕上并正确显示它。

答案 1 :(得分:4)

如果您将此扩展到其他命令,我认为您应该查看command pattern。 如果要扩展此计算方法,它将在将来减少if语句。

command-pattern with calculator

答案 2 :(得分:3)

更好的方法是返回值。如果您将方法命名为sum,则希望获得

您可以创建方法showResult()。您希望获得信息消息

public int getSum() {
    return this.sum;
}

public void showResult() {
    System.out.println("sum = " + this.sum); // add some description 
}

private void calculate() {
    this.sum = reader.readInteger() + reader.readInteger();
}