博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android线程——StackTraceElement线程运行栈的探索
阅读量:7088 次
发布时间:2019-06-28

本文共 5121 字,大约阅读时间需要 17 分钟。

个人博客 ,最新文章将会首发,欢迎探索哦 !

同时,搜索微信公众号CoorChice,或扫描文章末尾二维码,可以关注我的微信公众号。同期文章也将会优先推送到微信公众号中,以提醒您有新鲜文章出炉。

介绍

StackTraceElement[]中保存了一条线程中所有调用的方法。其中每个方法的信息包含在一个StackTraceElement对象中。

获取StackTraceElement中的信息

element.getClassName(); //获取类名element.getMethodLine(); //获取方法名element.getMethodName(); //获取方法名element.getFileName(); //获取包含类的文件名

StackTraceElement[]中的信息

StackTracelElement[]是一个的数组,以下标0为开始,其中在Java比较有用的是第3个,在Android中比较有用的是第4个,因为在Android中多了一个Dalvik的调用,所以实际Java中的第3位向后移动了一个位置,变成第4位。

这个比较有用的StackTraceElement保存了实际调用该方法的方法信息。

//下面方法能够打印一组当前线程的StackTraceElement[]信息:public static String showAllElementsInfo() {    String print = "";    int count = 0;    //从当前线程中获取所有的StackTraceElement    StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace();    for (StackTraceElement stackTraceElement : stackTraceElements) {      count++;      print += String.format("ClassName:%s " +          "\nMethodName:%s " +          "\nMethodLine:%d " +          "\n当前是第%d个 " +          "\n---------------------------- " +          "\n ",          stackTraceElement.getClassName(),          stackTraceElement.getMethodName(),          stackTraceElement.getLineNumber(),          count);    }    return print;  }    //我是在单元测试中调用的  @Test  public void testTestElement() throws Exception {    System.out.println(LogUtils.showAllElementsInfo());  }//下面是测试打印结果:ClassName:java.lang.Thread MethodName:getStackTrace MethodLine:1552 当前是第1个 ----------------------------  ClassName:com.example.chenbing.animdvedemo.Utils.LogUtils MethodName:showAllElementsInfo MethodLine:60 当前是第2个 ----------------------------  ClassName:com.example.chenbing.animdvedemo.Utils.LogUtilsTest MethodName:testTestElement MethodLine:32 当前是第3个 ----------------------------  ClassName:sun.reflect.NativeMethodAccessorImpl MethodName:invoke0 MethodLine:-2 当前是第4个 ----------------------------  ClassName:sun.reflect.NativeMethodAccessorImpl MethodName:invoke MethodLine:62 当前是第5个 ----------------------------  ClassName:sun.reflect.DelegatingMethodAccessorImpl MethodName:invoke MethodLine:43 当前是第6个 ----------------------------  ClassName:java.lang.reflect.Method MethodName:invoke MethodLine:498 当前是第7个 ----------------------------  ClassName:org.junit.runners.model.FrameworkMethod$1 MethodName:runReflectiveCall MethodLine:50 当前是第8个 ----------------------------  ClassName:org.junit.internal.runners.model.ReflectiveCallable MethodName:run MethodLine:12 当前是第9个 ----------------------------  ClassName:org.junit.runners.model.FrameworkMethod MethodName:invokeExplosively MethodLine:47 当前是第10个 ----------------------------  ClassName:org.junit.internal.runners.statements.InvokeMethod MethodName:evaluate MethodLine:17 当前是第11个 ----------------------------  ClassName:org.junit.internal.runners.statements.RunBefores MethodName:evaluate MethodLine:26 当前是第12个 ----------------------------  ClassName:org.junit.internal.runners.statements.RunAfters MethodName:evaluate MethodLine:27 当前是第13个 ----------------------------  ClassName:org.junit.runners.ParentRunner MethodName:runLeaf MethodLine:325 当前是第14个 ----------------------------  ClassName:org.junit.runners.BlockJUnit4ClassRunner MethodName:runChild MethodLine:78 当前是第15个 ----------------------------  ClassName:org.junit.runners.BlockJUnit4ClassRunner MethodName:runChild MethodLine:57 当前是第16个 ----------------------------  ClassName:org.junit.runners.ParentRunner$3 MethodName:run MethodLine:290 当前是第17个 ----------------------------  ClassName:org.junit.runners.ParentRunner$1 MethodName:schedule MethodLine:71 当前是第18个 ----------------------------  ClassName:org.junit.runners.ParentRunner MethodName:runChildren MethodLine:288 当前是第19个 ----------------------------  ClassName:org.junit.runners.ParentRunner MethodName:access$000 MethodLine:58 当前是第20个 ----------------------------  ClassName:org.junit.runners.ParentRunner$2 MethodName:evaluate MethodLine:268 当前是第21个 ----------------------------  ClassName:org.junit.runners.ParentRunner MethodName:run MethodLine:363 当前是第22个 ----------------------------  ClassName:org.junit.runner.JUnitCore MethodName:run MethodLine:137 当前是第23个 ----------------------------  ClassName:com.intellij.junit4.JUnit4IdeaTestRunner MethodName:startRunnerWithArgs MethodLine:69 当前是第24个 ----------------------------  ClassName:com.intellij.rt.execution.junit.JUnitStarter MethodName:prepareStreamsAndStart MethodLine:234 当前是第25个 ----------------------------  ClassName:com.intellij.rt.execution.junit.JUnitStarter MethodName:main MethodLine:74 当前是第26个 ----------------------------  ClassName:sun.reflect.NativeMethodAccessorImpl MethodName:invoke0 MethodLine:-2 当前是第27个 ----------------------------  ClassName:sun.reflect.NativeMethodAccessorImpl MethodName:invoke MethodLine:62 当前是第28个 ----------------------------  ClassName:sun.reflect.DelegatingMethodAccessorImpl MethodName:invoke MethodLine:43 当前是第29个 ----------------------------  ClassName:java.lang.reflect.Method MethodName:invoke MethodLine:498 当前是第30个 ----------------------------  ClassName:com.intellij.rt.execution.application.AppMain MethodName:main MethodLine:144 当前是第31个 ----------------------------
img_08b056b059ac831a2d371fa29bdef1e3.jpe
CoorChice的公众号

转载地址:http://awbql.baihongyu.com/

你可能感兴趣的文章
抖音成2018年全球iOS设备上下载最多的应用\n
查看>>
IBM核心软件如何应对“互联网+”的技术挑战
查看>>
Weaveworks增加发布自动化和事件管理
查看>>
LeetCode[337] House Robber III
查看>>
Weblogic 12c 使用 WLST 新建域
查看>>
快速掌握dockerfile
查看>>
Android动态设置主题(使用RxBus模式)
查看>>
CMake 简介和 CMake 模板
查看>>
SnapKit自动布局(三)
查看>>
SegmentFault D-Day 2016「天津站: 前端场」活动回顾
查看>>
我的Docker笔记(补全ing)
查看>>
Climbing Stairs leetcode
查看>>
The road you are trudging is bound for loneliness.(前行的道路注定孤独)
查看>>
Write Lean Programs
查看>>
django 1.8 官方文档翻译:9-2 "本地特色"附加功能
查看>>
大数据相关技术有哪些?
查看>>
和 Pipelining 说再见,cURL 放弃使用管道技术
查看>>
Egg 2.16.2 发布,企业级 Node.js 框架
查看>>
计算几何 - 最近点对 分治法
查看>>
大众继续深耕SUV市场:5款新车型先于上海车展登场,ID. ROOMZZ成点睛之笔 ...
查看>>