使用JAVA反射机制覆盖类的toString方法

编码的时候,相信很多时候需要打印出当前Entity的字段及值,用来做一些单元测试使用,但是如果每个Entity都去加一遍toString()方法,相信即使有工具帮忙,也是很麻烦的事,尤其是,如果在敏捷开发时,很多情况表的字段会改来改去,相应的Entity的字段也跟着改去改去,那么有没办法自动兼容所有字段变化,实现字段值的输出的呢,这就要用到JAVA强大的反射机制了,talk is cheap,show me code,OK,定义一个抽象类作为所有Entity的父类,然后覆盖toString()方法,然后利用反射机制获取当前实例的所有字段并获得值输出,就实现了这个思路,是不是减少了很多工作量呢?

/**
 * @ClassName BaseEntity
 * @Description 基础Entity对象
 * @Author wangd
 * @Create 2018-12-29 13:45
 */
public abstract class BaseEntity implements Serializable {

    @Override
    public String toString() {
        //通过反射获取所有类的当前字段
        Field[] declaredFields = getClass().getDeclaredFields();
        StringBuffer sb=new StringBuffer();
        sb.append(getClass().getName()+"{");
        for (Field field:declaredFields) {
            field.setAccessible(true);
            String fn = field.getName();
            try {
                sb.append(fn + "=" + field.get(this)+",");
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            }
        }
        sb.append("}");
        return sb.toString();
    }
}

猜你喜欢

转载自blog.csdn.net/blackhost/article/details/85338409