原文: https://javatutorial.net/java-builder-design-pattern

在这里,我们将讨论 Java 构建器设计模式,以及在何处以及如何使用它。

这种设计模式也称为创建设计模式,用于从简单对象创建和配置复杂对象。 因此,基本上,它可以帮助我们在生成复杂对象的同时编写可读性,可管理性和可理解性的代码。

构建器模式生成一个构建对象,该构建对象用于构建称为产品的复杂对象。 为了给出教科书的定义,“构建器设计模式将复杂对象的构造与其表示分开,以便相同的构造过程可以创建不同的表示。”

工厂设计模式也是一种创新设计模式。 在使用简单对象生成复杂对象时,必须严格遵循分步方法。 创建此设计模式是为了解决当对象包含许多属性时工厂和抽象工厂设计模式所产生的问题。

我们通常在哪里使用构建器设计模式?

  • 当需要对象的多种表示时
  • 客户传递的论点太多
  • 对象创建包含可选参数

这种类型的设计模式通常使用流畅的界面来实现。

构建器设计模式的实现

Java 中的每个类都有一个由用户显式设置或默认设置的构造函数。 当可以借助许多不同的参数(可能是强制性的,而其他参数也可能是可选的)创建对象时,将使用构建器模式。 在这种情况下,事情变得复杂并且容易出错。 因此,在这种情况下,构建器模式会派上用场。

实现构建器设计模式的步骤:

  1. 使用所有必填字段创建一个构建器类
  2. Builder类应具有带有所有必需参数的公共构造函数
  3. 创建方法以获取可选参数的值。 设置可选属性后,这些方法应返回相同的构建器对象。
  4. 最后,在Builder类中提供一个build()方法,该方法将返回所需的对象。

让我们看一个编码示例,该示例说明在创建复杂对象时如何实现构建器模式。 我们考虑了一个学生数据收集系统,并创建了一个处理此类特定数据收集的Student类。 如图所示,已生成并实现了一个名为StudentBuilder的构建器类。

让我们看一个例子

  1. public class Student {
  2. private int id;
  3. private String firstName;
  4. private String lastName;
  5. private int age;
  6. private String phone;
  7. private String address;
  8. private String course;
  9. public Student(StudentBuilder studentBuilder) {
  10. this.id = studentBuilder.id;
  11. this.firstName = studentBuilder.firstName;
  12. this.lastName = studentBuilder.lastName;
  13. this.age = studentBuilder.age;
  14. this.phone = studentBuilder.phone;
  15. this.address = studentBuilder.address;
  16. this.course = studentBuilder.course;
  17. }
  18. public int getId() {
  19. return id;
  20. }
  21. public String getFirstName() {
  22. return firstName;
  23. }
  24. public String getLastName() {
  25. return lastName;
  26. }
  27. public int getAge() {
  28. return age;
  29. }
  30. public String getPhone() {
  31. return phone;
  32. }
  33. public String getAddress() {
  34. return address;
  35. }
  36. public String getCourse() {
  37. return course;
  38. }
  39. @Override
  40. public String toString() {
  41. return "Student{" +
  42. "id=" + id +
  43. ", firstName='" + firstName + '\'' +
  44. ", lastName='" + lastName + '\'' +
  45. ", age=" + age +
  46. ", phone='" + phone + '\'' +
  47. ", address='" + address + '\'' +
  48. ", course='" + course + '\'' +
  49. '}';
  50. }
  51. public static class StudentBuilder {
  52. private int id;
  53. private String firstName;
  54. private String lastName;
  55. private int age;
  56. private String phone;
  57. private String address;
  58. private String course;
  59. public StudentBuilder(int id, String firstName, String lastName) {
  60. this.id = id;
  61. this.firstName = firstName;
  62. this.lastName = lastName;
  63. }
  64. public StudentBuilder withOptionalAge(int age) {
  65. this.age = age;
  66. return this;
  67. }
  68. public StudentBuilder withOptionalPhone(String phone) {
  69. this.phone = phone;
  70. return this;
  71. }
  72. public StudentBuilder withOptionalAddress(String address) {
  73. this.address = address;
  74. return this;
  75. }
  76. public Student buildStudent() {
  77. validateStudentData();
  78. return new Student(this);
  79. }
  80. private boolean validateStudentData() {
  81. //Validation process, check if student is registered in the database
  82. return true;
  83. }
  84. }
  85. }

在主要代码中使用构建器

  1. Student stu1 = new Student.StudentBuilder(12341, "Jack", "Harrison")
  2. .withOptionalAddress("Address")
  3. .withOptionalAge(21)
  4. .withOptionalPhone("874116073648")
  5. .buildStudent();
  6. System.out.println("Student : " + stu1.toString());
  7. Student stu2 = new Student.StudentBuilder(1225, "Diana", "Daniels")
  8. .withOptionalAge(18)
  9. .buildStudent();
  10. System.out.println("Student : " + stu2);