1、代码调用树查看
2、出错代码位置信息提示
功能函数:
/** 在LogCat中输出提示信息info,并给出输出该信息在代码中的完整调用树 */
public static void MessageWithSrcTree(String info)
{
StackTraceElement[] elem = Thread.currentThread().getStackTrace(); //从当前位置,获取代码调用堆栈
for(StackTraceElement e : elem)
{
String str = e.getFileName() + " " + e.getLineNumber() + "行:" + e.getClassName() + " -> " + e.getMethodName() + "()" ;
Gdx.app.error(info, str); //输出调用位置信息
// Log.e(info, str);
// System.out.println(info + " " + str);
}
}
// 当try块出错时,给出当前代码位置的,出错提示信息
// try{...}catch(Exception e){ Tools.MessageWithSrcSite("执行try{}时出错!"); }
public static void MessageWithSrcSite(String info)
{
StackTraceElement[] elem = Thread.currentThread().getStackTrace(); //从当前位置,获取代码调用堆栈
StackTraceElement e = elem[3]; //仅获取调用该函数的代码位置,不获取完整调用树
String str = e.getFileName() + " " + e.getLineNumber() + "行:" + e.getClassName() + " -> " + e.getMethodName() + "()" ;
Gdx.app.error(info, str); //输出调用位置信息
// Log.e(info, str);
// System.out.println(info + " " + str);
}
/** 在LogCat中输出提示信息info,并给出输出该信息在代码中的调用位置 */
public static String getClassName()
{
StackTraceElement[] elem = Thread.currentThread().getStackTrace(); // 从当前位置,获取代码的堆栈追踪信息
StackTraceElement e = elem[3]; // 仅获取调用该函数的代码位置,不获取完整调用树
String str = e.getClassName();
Gdx.app.error(e.getFileName(), str); // 输出调用位置信息和提示信息
return str;
// Log.e(info, str);
// System.out.println(info + " " + str);
}