常用打印堆栈方法

来源:互联网 发布:linux配置java环境 编辑:程序博客网 时间:2024/05/20 22:35

一、java中打印函数调用堆栈:

        + try{

        + throw new Exception("xxxxxx"); //抛出异常

        + }   catch (Exception e) {+ e.printStackTrace(); //接收异常+ }

         diff --git a/media/java/android/media/MediaPlayer.java b/media/java/android/media/MediaPlayer.javaindex e5a1a07..11224c7 100644---                                    a/media/java/android/media/MediaPlayer.java+++ b/media/java/android/media/MediaPlayer.java

@@ -1468,6 +1468,11 @@ public class MediaPlayer implements SubtitleController.Listener mTimeProvider.close(); mTimeProvider = null; }

        + try{+ throw new Exception("xxxxxx"); //抛出异常+ } catch (Exception e) {

        + e.printStackTrace(); //接收异常

        + } mOnSubtitleDataListener = null; 

        _release(); }


二、C++ 里打堆栈的方法:

      1.加头文件 #include <utils/CallStack.h>
 

       2.在需要打堆栈的函数里增加如下代码: 

       CallStack stack; 

        stack.update(); 

        stack.log("xxxxxx"); 


三、kernel中打印函数调用堆栈:

1、包含如下头文件:

       #include<linux/kprobes.h>

   #include <asm/traps.h>  

 2、在需要打印函数调用堆栈的地方添加如下信息: 

        printk(KERN_WARNING "dump satck start ====>\n");

        dump_stack(); 

        printk(KERN_WARNING "dump stack end <====\n");

0 0