http://blog.csdn.net/xinzheng_wang/article/details/7416543
http://www.2cto.com/kf/201205/132494.html
http://blog.csdn.net/mapdigit/article/category/1137396/4
http://tju-jusi.iteye.com/blog/1544778
http://blog.csdn.net/dxh040431104/article/details/5873235
http://www.cnblogs.com/cat-lee/archive/2011/07/09/2101718.html
native
一、 手机端准备工作
1、 安装库文件
所有的 native 内存分配函数 ( malloc , calloc , etc.) 都在 Android 的 libc 库中。为了跟踪堆内存的分配,需要使用这个库的特别版本,可以将每次内存开销记录下来。 这些特殊版本的 libc ( libc_malloc_debug_leak.so and libc_malloc_debug_qemu.so 可以在手机中的/system/lib 下查看是否有这两个库 ) 只包含在eng或者user-debug版的 Android中。 如果手机是这两种系统之一,可以跳过下一步。
①下载最接近你手机模型和 Android系统版本( 2.3 、 4.0 等)的 CyanogenMod ROM 。如果没有恰好是你手机的对应版本,那么选择处理器相同的 ( 比如 Tegra2) 和 Android系统版本(例如 2.3 )都相同的 rom. 。然后从 system/lib 文件夹 抽出 libc_malloc_debug_leak.so 和 libc_malloc_debug_qemu.so 。
②以中兴 U880 手机为例,手机本身是移动定制的 Android2.2 系统, CyanogenMod 官网上恰有中兴的 rom,但是系统版本为 2.3.7 ,并且手机需要 root 权限,所以使用 U880 刷机工具,刷U880_2.3.7 root 版 rom 。
2、 替换库
①从 CM 版 rom 中 /system/lib 文件夹中抽出 libc_malloc_debug_leak.so 和 libc_malloc_debug_qemu.so
②把 libc_malloc_debug_leak.so 和 libc_malloc_debug_qemu.so 通过 USB拷到 SDCARD卡根目录下。
③手机中安装 BusyBox 以便使用 cp 命令复制文件。
④PC端命令行中执行
- adb shell
- su
- mount
不同手机返回的值不同,如下两例
LG G2x:
...
/dev/block/mmcblk0p1 /system ext3 ro,noatime,errors=continue,data=ordered 0 0
...
中兴 U880 :
...
/dev/block/ mtdblock11 /system yaffs2 ro,relatime,barrier=1,data=ordered 0 0
...
第一部手机将 /dev/block/mmcblk0p1 作为设备, ext3 作为文件系统类型。
第二部手机将 /dev/block/ mtdblock11 作为设备, yaffs2 作为文件系统类型。
⑤使用上面得到的设备名,和文件系统类型,重新挂载系统分区为读写格式。如下所示:
LG G2x:
- mount -o remount,rw -t ext3 /dev/block/mmcblk0p1 /system
中兴 U880 :
- mount -o remount,rw -t yaffs2 /dev/block/ mtdblock11 /system
⑥ 把两个库文件从S DCARD 拷到 /system/lib 目录:
- cp /sdcard/libc_malloc_debug_leak.so /system/lib/libc_malloc_debug_leak.so
- cp /sdcard/libc_malloc_debug_qemu.so /system/lib/libc_malloc_debug_qemu.so
⑦ 设置权限
- chmod 0644 /system/lib/libc_malloc_debug_leak.so
- chmod 0644 /system/lib/libc_malloc_debug_qemu.so
3、 配置
① 替换完新的库文件后,告知系统使用新的库分配内存。
②命令行中执行
- adb shell
- su
- setprop libc.debug.malloc 1
支持的参数:
1 - perform leak detection 5 - fill allocated memory to detect overruns 10 - fill memory and add sentinels to detect overruns 20 - use special instrumented malloc/free routines for the emulator
|
③ 重启框架 ,命令行中继续执行
- stop
- start
如果命令成功,设备将在 1、 2 秒后重启, 注意并不是完全重启。
④ 检查配置
输入:
- getprop
将会得到很多信息,其中包括:
...
[libc.debug.malloc]: [1]
...
说明配置成功
二、PC设置
在C:\Documents and Settings\Administrator\.android\ ddms.cfg 文件末尾添加
native=true
三、检查泄露
从SDK\tools 中启动独立的 DDMS ( ddms.bat )可以看见 native heap 选项卡
点击snapshot current... 按钮就可以了,如果按下±按钮,在点击 snapshot current 可以比较两次之间新分配了哪些空间。
有人说使用自己用源码编译出来DDMS 和模拟器,下面的 stacktrace 中的 File 和 Line 列就有值了。我们用的是真机啊。。。没有关系 ~~
找到自己的库函数***.so 后面的 Method 列中的地址。使用 NDK 中的 addr2line 工具,
用法:在命令行中addr2line.exe -e ***\obj\local\armeabi\***.so 地址
注意,一定要是obj 底下的 .so , lib 里面的是不含有符号表的。另外 Method 中的地址一般要将高 3 位置 0 ,80cc6e22 变为 000c6e22 。 80dxxxxx 的怎么变自己领悟吧。。。
linux 驱动
List of devices attached
???????????? no permissions
同时在DDMS中显示设备名也显示????,也无法显示进程名,无法查看log。
一、工具介绍
android-sdk-linux_x86/tools下有一堆工具,今天要用的是:Android Debug Bridge,在android开发过程中,这个工具是使用得最多的。(缩写adb,有点像gcc的gdb似的)
adb start-server – 实际上它会启动一个 adb fork-server server
adb kill-server – kill掉
adb devices – 列出所有的设备
二、设置usb权限
因为ubuntu这样的系统都是默认以非root身份在运行的,要使用usb调试,需要sudo支持。
$ lsusb
Bus 005 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 004 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 003 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 002 Device 003: ID 413c:2106 Dell Computer Corp.
Bus 002 Device 002: ID 0461:4d81 Primax Electronics, Ltd
Bus 002 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 001 Device 010: ID 0bb4:0c87 High Tech Computer Corp.
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
列表中,Bus 001 Device 010: ID 0bb4:0c87 High Tech Computer Corp. 这一行为htc手机的usb使用端口,记录一下,id为0bb4(基于上所有的htc都是这个ID)。
$sudo vim /etc/udev/rules.d/70-android.rules
加入以下内容:
SUBSYSTEM=="usb", ATTRS{idVendor}=="0bb4", ATTRS{idProduct}=="0c87",MODE="0666"
其中的idvendor idProduct指的是USB的ID可以使用lsusb查询得到。
比如我的是:
lsusb
Bus 001 Device 010: ID 0bb4:0c87 High Tech Computer Corp
ID 0bb4 就是idVendor ,0c87就是 idProduct
运行命令,重启udev:
$sudo chmod a+rx /etc/udev/rules.d/70-android.rules
$sudo service udev restart
三、重新启动adb server
(很重要)拔掉usb重新连上再执行:
sudo ./adb kill-server
./adb devices
./adb root (这一步很重要 )
四、使用usb进行调试
问题说明中的问题至此已经得到解决。
在DDMS选择相应的devices,可以看到log了。。。。
五、知识积累
1. Gooogle udev
2.拔插usb,使用以下命令可以实时监视系统信息
sudo tail -f /var/log/messages
六、参考
1. http://edu.codepub.com/2010/1229/28405.php
2. http://blog.csdn.net/zhenwenxian/archive/2010/09/23/5901350.aspx
Finish Whatever U've Started !!!