热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Androidframework添加log

经测试,可以ALOGE可以打印出文件名、行号和函数名。ALOGE(###[%s(%d)-%s]:******,__FILE__,__LINE__,__FUNCTI
经测试,可以ALOGE可以打印出 文件名、行号和函数名。

ALOGE("### [%s(%d)-%s] : ******",__FILE__,__LINE__,__FUNCTION__);




[frameworks/av/media/libstagefright/HardwareRenderer.cpp(348)-render] : 


===================




参考  http://blog.csdn.net/loovejava/article/category/916212

 

android杂记--C++文件的添加log方法


分类: Android 624人阅读 评论(0) 收藏 举报

1.添加头文件

[cpp] view plaincopyprint?
  1. #include   
  2. 或者  
  3. #include   
这个时候可以使用ALOGE/ALOGI/ALOGW 等方法打印出log


不过有些地方不能这么使用,因为依赖libutils libctuils库

在mk文件见添加如下依赖编译即可

[plain] view plaincopyprint?
  1. #LOCAL_MODULE := ... ...   
  2. #base_intermediates := $(call local-intermediates-dir)  //该行之下添加,这个貌似是查找依赖文件  
  3. LOCAL_SHARED_LIBRARIES += \  
  4.         libutils libcutils  
  5.   
  6.     ... ...  
  7.   
  8. include $(BUILD_SHARED_LIBRARY) //该行之上,这时候是开始编译  


2.通常的堆栈


[cpp] view plaincopyprint?
  1. android::CallStack stack;  
  2. stack.update(1);  
  3. stack.dump("");  


这个需要加个头文件,不过要特别注意一个问题,这个头必须加在所有头的末尾,不然用不了滴,尤其是看android源码里webkit的时候。需要加的头文件如下:

[cpp] view plaincopyprint?
  1. #include   


今天有事,后续补全,如果大家有更好的,或者特殊的情况,欢迎推荐


3.C++另类堆栈


这个方法是可文件控制的。通过对android设备中的文件读写,然后空指针赋值,这样就可以达到文件控制的目的

该方法好处只要是C、C++文件均可添加此log,无依赖,便捷!也有个不好处,log只能运行到你添加的地方,因为崩库了,后面的无法运行了。


实现代码如下:


[cpp] view plaincopyprint?
  1. FILE *fp = NULL; //需要注意  
  2. fp = fopen("data/test""r");  
  3. if(NULL == fp)  
  4. {  
  5.     return false//需要返回值时使用  
  6. } esle {  
  7.     fclose(fp);  
  8.     int *fp = NULL;  
  9.     *fp = 100;  //空指针赋值出错,小样就它错了  
  10.     return false//需要返回值时使用  
  11. }  


一般崩库了是看不到堆栈的,我们可以通过反汇编来查看具体的堆栈。

在android里编译出的库有两套:一套无符号的,是查看不了的,另一套是有符号的,我们查看的就是这套,

有符号的编译出来后是在路径(\out\target\product\generic\symbols\system\lib)下

android中自带有arm的反汇编工具,在设置后编译环境后就可以正常使用了,命令如下:

[plain] view plaincopyprint?
  1. arm-eabi-addr2line -f -e **.so 地址1 地址2 ... ...  


推荐阅读
  • CentOS7.8下编译muduo库找不到Boost库报错的解决方法
    本文介绍了在CentOS7.8下编译muduo库时出现找不到Boost库报错的问题,并提供了解决方法。文章详细介绍了从Github上下载muduo和muduo-tutorial源代码的步骤,并指导如何编译muduo库。最后,作者提供了陈硕老师的Github链接和muduo库的简介。 ... [详细]
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的步骤和方法
    本文介绍了在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的详细步骤和方法。首先需要下载最新的Java SE Development Kit 9发行版,然后按照给出的Shell命令行方式进行安装。详细的步骤和方法请参考正文内容。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • MongoDB用户验证auth的权限设置及角色说明
    本文介绍了MongoDB用户验证auth的权限设置,包括readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、cluster相关的权限以及root权限等角色的说明和使用方法。 ... [详细]
  • C语言常量与变量的深入理解及其影响
    本文深入讲解了C语言中常量与变量的概念及其深入实质,强调了对常量和变量的理解对于学习指针等后续内容的重要性。详细介绍了常量的分类和特点,以及变量的定义和分类。同时指出了常量和变量在程序中的作用及其对内存空间的影响,类似于const关键字的只读属性。此外,还提及了常量和变量在实际应用中可能出现的问题,如段错误和野指针。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • html结构 ... [详细]
author-avatar
曾经沧海难为水文杰59552066
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有