为什么我的setter和getter方法不起作用?

时间:2013-03-30 03:07:13

标签: java methods setter getter

我一直在查看我的源代码,但无法弄清楚它有什么问题。 我认为问题在于Circle类。当我调用mutator和accessors时 DriverCircle类它给了我错误的输出。对于getDiameter,它只是打印出0。

public class Circle{
    private double radius;  
    private double pi;
    private double diameter;
    private double circumference;
    private double area; 

    public Circle(){
        pi = Math.PI;
        radius = 0;
    }

    public Circle(double radius){
        this.radius = radius;
    }
    public void setDiameter(){
        diameter = (2 * radius);
    }
    public double getDiameter(){
        //diameter = 2 * radius;
        return diameter;
    }
    public void setCircumference(){
        circumference = (2 * pi * radius);
    }
    public double getCircumference(){
        //circumference = 2 * pi * radius;
        return circumference;
    }
    public double getArea(){
        //area = pi * Math.pow(radius, 2);
        return area;
    }
    public void setArea(){
        area = (pi * Math.pow(radius, 2));
    }
    public void setRadius(double radius){
        this.radius = radius;
    }
    public double getRadius(){
        return radius;
    }
    public String toString(){
        return "The radius is " + radius;
    }
}

(测试员)......

import java.util.Scanner;

public class CircleDriver {

    public static void main(String[] args) {

        Scanner input = new Scanner(System.in);
        System.out.println("Please enter the radius: ");
        Circle[] circles = new Circle[10];
        Circle objectCircle = new Circle();
        objectCircle.setRadius(input.nextDouble());


        circles[1] = new Circle();
        circles[2] = new Circle(2.0);
        circles[3] = new Circle(3.5);
        circles[4] = new Circle(5.0);
        circles[5] = new Circle(0.0);
        circles[6] = new Circle(15);
        circles[7] = new Circle(25);
        circles[8] = new Circle(-7);
        circles[9] = new Circle(-10.0);

        System.out.println("Initial call to toString():");
        for (Circle c : circles)
            {System.out.println("\t" + c);}

        System.out.println("Call to getRadius (should be same as above):");
        for (Circle r : circles)
            {if (r != null)
                {System.out.println("\t" + r.getRadius());}}

        System.out.println("Call to getDiameter (should be twice the value shown above):");
        for (Circle d : circles)
            {if (d != null)
                {System.out.println("\t" + d.getDiameter());}}

        System.out.println("Calls to getCircumference:");
        System.out.println("\tShould be 2 * PI:  " + circles[1].getCircumference());
        System.out.println("\tShould be 0.0:  " + circles[5].getCircumference());

        System.out.println("\nCall to getArea:");
        System.out.println("\tShould be PI:  " + circles[1].getArea());
        System.out.println("\tShould be 0.0:  " + circles[5].getArea());

        System.out.println("Testing out the setRadius method:");
        for (int i = 0; i < circles.length / 2; i++)
            {if (circles[i] != null)
                {circles[i].setRadius(i);}}

        System.out.println("Call to toString after setting the first half of the objects:");
        for (Circle c : circles)
            {System.out.println("\t" + c);}
    }
}

6 个答案:

答案 0 :(得分:2)

您的setter方法应该有参数并使用参数来设置字段。否则它们实际上不是setter方法。除了setRadius(...)之外,你当前的setter方法都应该被丢弃,并且大多数计算都是在相应的getter方法中完成的。

即,不是

public void setCircumference(){
    circumference = (2 * pi * radius);
}

public double getCircumference(){
    //circumference = 2 * pi * radius;
    return circumference;
}

而是

public double getCircumference(){
    return 2 * Math.PI * radius;
}

答案 1 :(得分:1)

在构造函数中提供值时,

pi未初始化。此外,将pi存储为实例成员有点奇怪。只需在计算中使用Math.PI。

答案 2 :(得分:1)

您永远不会致电setDiameter()。您的构造函数设置半径的值,但它不会设置直径变量!

您可能只想重写getDiameter()

public double getDiameter() {
    return 2.0 * radius;
}

答案 3 :(得分:0)

您构建了一个圆形对象,用于设置半径,但您从未设置直径。应该从构造函数中调用setDiameter()。

更好的是,删除setDiameter()方法,因为它完全没必要。只需使getDiameter()返回2 * radius。

答案 4 :(得分:0)

我看到两个问题。

首先,如果使用双构造函数,则不要设置pi的值。您还应该使用no-args构造函数以及设置radius的值:

 public Circle(double radius){
    this(); // calls the no-args constructor
    this.radius = radius;
 }

其次,没有明确调用setDiameter()。有趣的是,这种方法用词不当 - 应该在半径非零时计算。 setArea的方式相同 - 您没有将任何内容传递给该方法调用。以下是我的建议:

  • setDiameter重命名为calculateDiameter以明确其意图。重命名的原因是让此类遵循关于set和get的JavaBean约定。
  • public Circle(double radius)中,请立即致电calculateDiameter()
  • 每当调用setRadius()时,要么立即调用calculateDiameter,要么违反JavaBean约定,并在设置值后立即调用它。
  • 我们强烈建议getArea做同样的事情,但我会将这部分作为练习留给读者。

在代码中,一个简短的例子:

 public Circle(double radius){
     this(); // calls the no-args constructor
     this.radius = radius;
     calculateDiameter();
 }

 public void setRadius(double r) {
     radius = r;
     calculateDiameter();
 }

答案 5 :(得分:0)

设置半径不会更新使用半径的每个函数;您必须显式调用这些函数,否则它们将保持Java的默认值0。 我也会在Circle(radius)方法中进行任何错误检查;这样,没有负数使其成为半径集。