先看个例子:
class Person{ private String name; private Date birthday; public String getName() { return name; } public void setName(String name) { this.name = name; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } @Override public String toString(){ return "name = " + this.name+" " + "birthday = " + this.birthday; } } public static void main(String[] args) throws Exception { String bd = "1991-01-01"; Person p = new Person(); BeanUtils.setProperty(p, "name", "zhangxx"); System.out.println(p); }
输出结果很明显:name = zhangxx birthday = null
现在我添加一个转换器,代码如下
class MyConverter implements Converter { public Object convert(Class type, Object value) { return "lixx"; } } //修改下主函数代码,将转换器注册到String类型上 public static void main(String[] args) throws Exception { String bd = "1991-01-01"; Person p = new Person(); MyConverter c = new MyConverter(); ConvertUtils.register(c,String.class); BeanUtils.setProperty(p, "name", "zhangxx"); System.out.println(p); }
输出结果是:name = lixx birthday = null
由上面的可以看出,BeanUtils.setProperty给对象属性赋的值,是转换器返回的值
如上面我为String类型注册了一个转换器,转化器返回值为lixx,那么Perspon中的所有类型为String的属性 赋的值都为lixx
因为ConvertUtils.register函数支持8种基本类型与String自动转换
所以当我们属性的类型为8种基本类型时,我们赋的值为String类型时,可以不用考虑ConvertUtils.register方法
但当属性值不是8种基本类型,而我们赋String类型,则需要重写ConvertUtils.register方法
如BeanUtils.setProperty(p, "birthday", bd);这个语句会报错,我们需要注册一个Date转换器。
ps:类型一致赋值也是成功的,像BeanUtils.setProperty(p,"birthday",new Date())是可行的