0

我需要对 setter 方法进行一些过滤并考虑修改它们,例如:

class Dog{
    int speed;

    public int getSpeed() {
        return speed;
    }
    public void setSpeed(int speed) {
        if(speed < 100)
            this.speed = speed;
        else
            this.speed = 100;
    }
} 

我不记得有任何这样的实现,它可能不合法(或至少不正确)。setFilteredSpeed(int speed)而不是这个,我应该写额外的 setter 方法,命名setSpeed(int speed)为默认值吗?这种方式似乎不是破豆的方式。

class Dog{
    int speed;

    public int getSpeed() {
        return speed;
    }
    public void setSpeed(int speed) {
        this.speed = speed;
    }
    public void setFilteredSpeed(int speed) {
        if(speed < 100)
            setSpeed(speed);
        else
            setSpeed(100);
    }
} 

第三种选择是准备像这样的单独过滤器类:

class DogFilter{

    public int doSpeed(int speed) {
        if(speed < 100)
            return speed;
        else
            return 100;
    }
}

class Main(){
    public static void main(){
        Dog dog = new Dog();
        dog.setSpeed(DogFilter.doSpeed(165));
    }
}

我认为这是常见的用法;但第二种选择似乎更接近 OOP 方法。哪种方式是正确的方式?

4

2 回答 2

2

假设您实际上想要完全防止无效速度,您的第一个选择是正确的方法

于 2013-01-10T22:05:56.713 回答
1

如果speed永远不会高于 100,则第一个解决方案就足够了。对于其他两种解决方案,您需要确保所有可能设置无效(太高)的类都speed使用适当的方法,这很容易出错。

于 2013-01-10T22:07:24.013 回答