android 输出变量的值,android 中施用Java反射Reflect,输出类中变量值,方便调试

android 中使用Java反射Reflect,输出类中变量值,方便调试。

Android开发中调试中,我们经常需要输出类的数据。

例如我们经常需要看一下,下列Data类的数据。

public class Data {

private int id;

private String name;

private String url;

private Bitmap bitmap;

private Long t;

private String status;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

//... ... 节省版面

}

代码如下:

工具类:

LogHelper.java

import java.lang.reflect.Method;

public class Trace {

public static void Reflect_Object(Object o, String classPath) {

if (null == o || null == classPath) return;

try {

Class> userClass = Class.forName(classPath);// 加载类

Method[] methods = userClass.getDeclaredMethods();// 获得类的方法集合

// 遍历方法集合

System.out.println("=== start traversing getXX methods====");

for (int i = 0; i < methods.length; i++) {

// 获取所有getXX()的返回值

// methods[i].getName()方法返回方法名

if (methods[i].getName().startsWith("get")) {

Object object = methods[i].invoke(o);

System.out.println(" " + methods[i].getName() + "() : " + object);

}

}

System.out.println("=== end ====");

} catch (Exception e) {

e.printStackTrace();

}

}

}

使用非常方便:

Data dat = new Data();

//TODO dat 赋值,操作等。。

... ....

// 调用助手,输出信息

Trace.Reflect_Object(dat, Data.class.getName());

完毕.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值