软件设计重构秘笈23式-22引入参数对象
概念
本文中的“引入参数对象”是指当一个方法的参数过多或者过为复杂时,可以考虑把这些参数封装成一个单独的类。
意图
引入参数对象为了提高代码的可读性,可维护性
如果一个方法所需要的参数大于5个,理解该方法的签名就变得比较困难,因为这样感觉参数很长、样式不好并且没有分类,
所以我们有必要把参数进行封装。
案例
public class Registration {
public void create(double amount, Student student, List<Course> courses, double credits){
// do work
}
}
public class Course {
}
public class Student {
}
重构
通常这种情形下创建一个用户传递参数的类是很有帮助的,这会使得代码更容易明白也更灵活,因为当你需要增加参数时,
只需要给参数类添加一个属性即可。请注意只有当你发现方法的参数比较多时才应该应用该重构,如果方法的参数比较少,
就没有必要应用此重构,因为该重构会增加系统中类的数量,同时也会加大维护负担。所以要看参数情况而定。
重构后的代码如下:
public class RegistrationContext {
private double amount;
private Student student;
private List<Course> courses;
private double credits;
public double getAmount() {
return amount;
}
public void setAmount(double amount) {
this.amount = amount;
}
public Student getStudent() {
return student;
}
public void setStudent(Student student) {
this.student = student;
}
public List<Course> getCourses() {
return courses;
}
public void setCourses(List<Course> courses) {
this.courses = courses;
}
public double getCredits() {
return credits;
}
public void setCredits(double credits) {
this.credits = credits;
}
}
public class Registration {
public void create(RegistrationContext registrationContext){
// do work
}
}
总结
这种重构很重要,尤其是当一个方法的参数比较多的时候,不管是大中型项目还是小型项目,都会遇到这种场景,所以建议大家多使用这个重构。
这种封装的思想在SOA 里面也经常运用到,封装输入Message,封装输出Message,消息来和消息去以及消息间的交互就构成了整个应用体系。