打印Java对应中每个类的属性和它对应的值

我们在打印日志的过程中,经常需要复写父类的toString方法,如果一个一个的去拼接属性名和属性值,那么代码会显得非常冗余,重复性很大。我们完全可以按照反射来快速获取。

比如我们的bean类,核心在于toString方法。

public class Bean {
	
	private String name = "abc";
	
	private String age = "15";
	
	private boolean success = true;
	
	private Long money = 5000L;
	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getAge() {
		return age;
	}

	public void setAge(String age) {
		this.age = age;
	}

	public boolean isSuccess() {
		return success;
	}

	public void setSuccess(boolean success) {
		this.success = success;
	}

	public Long getMoney() {
		return money;
	}

	public void setMoney(Long money) {
		this.money = money;
	}

	@Override
	public String toString(){
		// 要打印出来的日志
		StringBuffer result = new StringBuffer();
		try {
			// 获得当前类的Class
			Class<? extends Bean> clazz = this.getClass();
			
			// 获取当前类的全部属性
			Field [] fields = clazz.getDeclaredFields();
			for (Field field : fields) {
				
				// 遍历属性得到属性名
				String fieldName = field.getName();
				
				// 如果是用于序列化的直接过滤掉
				if ("serialVersionUID".equals(fieldName)) {
					continue;
				}
				
				// 判断属性的类型,主要是区分boolean和其他类型
				Class<?> type = field.getType();
				
				// boolean的取值是is,其他是get
				String methodName = (type.getTypeName().equals("boolean")?"is":"get")
						+ fieldName.substring(0,1).toUpperCase() 
                        + fieldName.substring(1, fieldName.length());
				
				Method method;
				java.lang.Object resultObj;
				
				// 通过方法名得到方法对象
				method = clazz.getMethod(methodName);
				
				// 得到这个方法的返回值
				resultObj = method.invoke(this);
				
				// 将属性名和它对应的值进行匹配打印
				if (resultObj != null && !"".equals(resultObj)) {
					result.append("[").
                         append(fieldName).append("]").append(resultObj).append(" ");
				}
			}
		} catch (SecurityException | NoSuchMethodException | IllegalAccessException 
              | IllegalArgumentException | InvocationTargetException e) {
			e.printStackTrace();
		}
		return result.toString();
	}
}

测试代码:

	public static void main(String[] args) {
		Bean bean = new Bean();
		System.out.println(bean.toString());
	}

执行结果:

[name]abc [age]15 [success]true [money]5000 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值