线程运行栈StackTrace用法,代码调用树查看,出错代码位置信息提示,代码所在类名包名文件名查看

48 篇文章 0 订阅


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);
	}
	











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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值