我们在编程或阅读前人的代码时,经常会看到多个参数的方法,有的甚至达到二十个,看得人眼花缭乱,不便于阅读和维护,而且参数很容易混淆,如两个参数类型同为short型,传递时相互颠倒,编译期间内不会提示报错,如下面这个方法:
public void updateUseInfo(String name, String cardNo, String phoneNunmber,String address, String edu, short age,short sex,
float height, float weight, Date birthday) {
// 更新操作
}
记忆术中有个“魔数之七”的说法,大多数人一次最多只能记忆7个独立的块,我们将短期记忆量控制在7个之内,将大大提高记忆效率,因此建议将方法参数控制在7个以内,在4个以内最好,但是需要传递的方法参数就那么多,该怎么办?
一种方法是将一个方法拆分成多个方法,每个方法传递少量参数,然而有时候这些参数需要同时被使用,我们也可以使用参数对象封装这些参数,如对上面方法进行改造:
class UserInfo {
private String name;
private String cardNo;
private String phoneNunmber;
private String address;
private String edu;
private short age;
private short sex;
private float height;
private float weight;
private Date birthday;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCardNo() {
return cardNo;
}
public void setCardNo(String cardNo) {
this.cardNo = cardNo;
}
public String getPhoneNunmber() {
return phoneNunmber;
}
public void setPhoneNunmber(String phoneNunmber) {
this.phoneNunmber = phoneNunmber;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String getEdu() {
return edu;
}
public void setEdu(String edu) {
this.edu = edu;
}
public short getAge() {
return age;
}
public void setAge(short age) {
this.age = age;
}
public short getSex() {
return sex;
}
public void setSex(short sex) {
this.sex = sex;
}
public float getHeight() {
return height;
}
public void setHeight(float height) {
this.height = height;
}
public float getWeight() {
return weight;
}
public void setWeight(float weight) {
this.weight = weight;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
}
新方法:
public void updateUseInfo(UserInfo uInfo) {
// 更新操作
}
参数对象对参数进行了封装,后期还可以往对象中添加新的相关参数,方便阅读,维护和功能扩展,但是需要花费一部分精力来设计这些对象,否则很容易被滥用。
比如你写一个方法,通过用户名称和证件号查询相关信息:
public void queryUserRelatedInfo(UserInfo uInfo){
//查询相关信息
}
这样写调用方不知道要往对象中设置哪些必要参数,实际上要使用这个方法,他还得进入方法内部查看实际使用了哪些参数,这个方法反而显得不够友好,如果直接改写为:
public void queryUserRelatedInfo(String name, String cardNo){
//查询相关信息
}
这个方法虽然多了个参数,但耦合度更低,对调用方更加友好。
随着用户信息的扩展,有的人会偷懒往userInfo对象中添加新的属性,如fatherName,motherName,这些属性缺乏紧密的联系,对象日渐庞大,整个就是一锅大杂烩,在可读性上反而不如直接传递基本类型参数的方法,这时候,我们需要对对象内部属性进行分类,将其中紧密联系的几个属性提取出来,构造成新的对象,如针对用户地址信息可以设计Address类,针对用户家人信息可以设计一个Family类,参数对象是一把双刃剑,关键是要考察代码实际情况,不滥用,要用就要提前设计好,用得恰到好处。