Создание подкласса класса Java Builder

Датьэта статья доктора Доббсаи, в частности, шаблон Builder, как мы справляемся со случаем создания подкласса Builder? Если взять сокращенную версию примера, в котором мы хотим создать подкласс для добавления меток ГМО, наивной реализацией будет:

public class NutritionFacts {                                                                                                    

    private final int calories;                                                                                                  

    public static class Builder {                                                                                                
        private int calories = 0;                                                                                                

        public Builder() {}                                                                                                      

        public Builder calories(int val) { calories = val; return this; }                                                                                                                        

        public NutritionFacts build() { return new NutritionFacts(this); }                                                       
    }                                                                                                                            

    protected NutritionFacts(Builder builder) {                                                                                  
        calories = builder.calories;                                                                                             
    }                                                                                                                            
}

Подкласс:

public class GMOFacts extends NutritionFacts {                                                                                   

    private final boolean hasGMO;                                                                                                

    public static class Builder extends NutritionFacts.Builder {                                                                 

        private boolean hasGMO = false;                                                                                          

        public Builder() {}                                                                                                      

        public Builder GMO(boolean val) { hasGMO = val; return this; }                                                           

        public GMOFacts build() { return new GMOFacts(this); }                                                                   
    }                                                                                                                            

    protected GMOFacts(Builder builder) {                                                                                        
        super(builder);                                                                                                          
        hasGMO = builder.hasGMO;                                                                                                 
    }                                                                                                                            
}

Теперь мы можем написать код так:

GMOFacts.Builder b = new GMOFacts.Builder();
b.GMO(true).calories(100);

Но, если мы получим неправильный заказ, все закончится неудачей:

GMOFacts.Builder b = new GMOFacts.Builder();
b.calories(100).GMO(true);

Проблема, конечно, в том, чтоNutritionFacts.Builder возвращаетNutritionFacts.BuilderнеGMOFacts.BuilderИтак, как мы решаем эту проблему, или есть лучший шаблон для использования?

Замечания:этот ответ на аналогичный вопрос предлагает классы, которые у меня есть выше; Мой вопрос касается проблемы обеспечения того, чтобы вызовы строителя были в правильном порядке.

Ответы на вопрос(10)

Ваш ответ на вопрос