あなたの場合、コンストラクターに固執してください。情報は顧客に属し、4 つのフィールドは問題ありません。
多くの必須フィールドとオプション フィールドがある場合、コンストラクターは最適なソリューションではありません。@boojiboy が言ったように、読みにくく、クライアント コードを書くのも難しいです。
@contagious は、オプションの属性にデフォルトのパターンとセッターを使用することを提案しました。これは、フィールドが変更可能であることを義務付けていますが、それは小さな問題です。
Effective Java 2 の Joshua Block は、この場合はビルダーを検討する必要があると述べています。本からの例:
public class NutritionFacts {
private final int servingSize;
private final int servings;
private final int calories;
private final int fat;
private final int sodium;
private final int carbohydrate;
public static class Builder {
// required parameters
private final int servingSize;
private final int servings;
// optional parameters
private int calories = 0;
private int fat = 0;
private int carbohydrate = 0;
private int sodium = 0;
public Builder(int servingSize, int servings) {
this.servingSize = servingSize;
this.servings = servings;
}
public Builder calories(int val)
{ calories = val; return this; }
public Builder fat(int val)
{ fat = val; return this; }
public Builder carbohydrate(int val)
{ carbohydrate = val; return this; }
public Builder sodium(int val)
{ sodium = val; return this; }
public NutritionFacts build() {
return new NutritionFacts(this);
}
}
private NutritionFacts(Builder builder) {
servingSize = builder.servingSize;
servings = builder.servings;
calories = builder.calories;
fat = builder.fat;
soduim = builder.sodium;
carbohydrate = builder.carbohydrate;
}
}
そして、次のように使用します。
NutritionFacts cocaCola = new NutritionFacts.Builder(240, 8).
calories(100).sodium(35).carbohydrate(27).build();
上記の例は、Effective Java 2から取得したものです。
そして、それはコンストラクターだけに当てはまるわけではありません。実装パターンでKent Beckを引用:
setOuterBounds(x, y, width, height);
setInnerBounds(x + 2, y + 2, width - 4, height - 4);
四角形をオブジェクトとして明示的にすると、コードがよりよく説明されます。
setOuterBounds(bounds);
setInnerBounds(bounds.expand(-2));