android Native堆

  Android 应用开发大家都知道可以通过DDMS来查看应用程序进程占用的内存大小;然而Native
内存并不能在虚拟堆上看到;Android系统基于Linux,这样的话其具备Linux的大多数特性;在Linux当中有不少方法可以查看进程占用的内存,可以采用图形界面工具,也可以采用命令,具体如何查看这边就不介绍了。

     Android Native 内存查看:

1.首先需要确保你的PC上装了adb工具;不同平台安装相应的版本。

2.adb shell 然后通过ps 命令查看手机上的进程。

  

[html] view
plain
 copy

  1. u0_a101   18271 174   656392 32856 ffffffff 00000000 S com.baidu.map.location  
  2. u0_a101   18286 174   654332 34288 ffffffff 00000000 S com.baidu.map.location:re  
  3. mote  
  4. u0_a58    18325 174   673716 38868 ffffffff 00000000 S com.xiaomi.channel:pushse  
  5. rvice  
  6. u0_a58    18347 174   688288 43628 ffffffff 00000000 S com.xiaomi.channel  
  7. root      18380 2     0      0     ffffffff 00000000 S kworker/0:3  
  8. u0_a11    18440 174   686980 41256 ffffffff 00000000 S com.google.process.gapps  
  9. u0_a11    18470 174   674016 36508 ffffffff 00000000 S com.google.android.gms  
  10. u0_a11    18497 174   676944 38440 ffffffff 00000000 S com.google.android.gsf.lo  
  11. gin  
  12. u0_a11    18517 174   684580 41268 ffffffff 00000000 S com.google.process.locati  
  13. on  
  14. u0_a12    18588 174   654444 32760 ffffffff 00000000 S com.miui.cloudservice  
  15. u0_a74    18623 174   838968 123264 ffffffff 00000000 R com.android.chrome  
  16. u0_i134   18654 174   747068 56468 ffffffff 00000000 S com.android.chrome:sandbo  
  17. xed_process0  
  18. u0_a23    18767 174   654368 32372 ffffffff 00000000 S com.google.android.partne  
  19. rsetup  

3.查看进程:下面以com.android.chrome为例

找到com.android.chrome 进程id是18623:在终端上输入:

[plain] view
plain
 copy

  1. shell@android:/ $ cat /proc/18623/status  

[plain] view
plain
 copy

  1. cat /proc/18623/status  
  2. Name:   .android.chrome  
  3. State:  S (sleeping)  
  4. Tgid:   18623  
  5. Pid:    18623  
  6. PPid:   174  
  7. TracerPid:      0  
  8. Uid:    10074   10074   10074   1007  
  9. Gid:    10074   10074   10074   1007  
  10. FDSize: 256  
  11. Groups: 1006 1015 1028 3003  
  12. VmPeak:   842864 kB  
  13. VmSize:   811216 kB  
  14. VmLck:         0 kB  
  15. VmPin:         0 kB  
  16. VmHWM:    126080 kB  
  17. <strong>VmRSS:    125484 kB</strong>  
  18. VmData:    69156 kB  
  19. VmStk:       136 kB  
  20. VmExe:         8 kB  
  21. VmLib:     68128 kB  
  22. VmPTE:       298 kB  
  23. VmSwap:        0 kB  
  24. Threads:        46  
  25. SigQ:   0/14952  
  26. SigPnd: 0000000000000000  
  27. ShdPnd: 0000000000000000  
  28. SigBlk: 0000000000001204  
  29. SigIgn: 0000000000000000  
  30. SigCgt: 00000002000094e8  
  31. CapInh: 0000000000000000  
  32. CapPrm: 0000000000000000  
  33. CapEff: 0000000000000000  
  34. CapBnd: ffffffffffffffff  
  35. Cpus_allowed:   f  
  36. Cpus_allowed_list:      0-3  
  37. voluntary_ctxt_switches:        2759  
  38. nonvoluntary_ctxt_switches:     2591  

4.分析内存

  熟悉Linux的童鞋知道proc目录下存放的是进程的各种信息;

  第三步中看到的VmRSS就是进程当前占用的实际内存。

  具体其他参数可以参考:进程信息参数详解

   

[plain] view
plain
 copy

  1. <span style="font-size:18px">rss %ld     (24) Resident Set Size: number of pages the  
  2.                          process has in real memory.  This is just the  
  3.                          pages which count toward text, data, or stack  
  4.                          space.  This does not include pages which have not  
  5.                          been demand-loaded in, or which are swapped out.</span>  

5.ps会列出很多进程我们有时候需要直接找到对应的进程,linux大家都知道可以通过grep、或者find找到直接找到进程;

adb shell;trim版本的linux ,不直接支持这些命令;不过有个方法是通过busybox来解决;下面以查找chrome为例:

[plain] view
plain
 copy

  1. <span style="font-size:18px">shell@android:/ $ ps | busybox grep chrome  
  2. ps | busybox grep chrome  
  3. u0_a74    18623 174   837800 125568 ffffffff 00000000 S com.android.chrome  
  4. u0_i134   18654 174   752124 55908 ffffffff 00000000 S com.android.chrome:sandbo  
  5. xed_process0</span>  
时间: 2024-10-27 06:04:09

android Native堆的相关文章

《深入解析Android 5.0系统》——第6章,第6.2节Android native层的同步方法

6.2 Android native层的同步方法 深入解析Android 5.0系统 Android在Linux提供的线程同步函数的基础上进行了二次封装,让实现线程同步更加简单方便.这些同步类和函数在native层的代码中出现的非常频繁. 6.2.1 互斥体Mutex和自动锁Autolock Mutex和Autolock是Android native层最常见的一种临界区保护手段,Autolock只是提供了一种更简便的使用Mutex的方法. Mutex是一个C++的类,它的接口如下所示: clas

webview网页交互-android native开发与android和网页交互相关问题

问题描述 android native开发与android和网页交互相关问题 webview中打开一个网页,网页中的按钮点击会跳转这个链接native-api://{"native-proc":{"api-name":"ChangesScreenToConfiguration","parames":""},"success-js-proc":"","erro

从零开始怎么写android native service?

从零开始怎么写android native service         Android service对于从事android开发的人都不是一个陌生的东西,很多人可能会觉得服务很简单.服务是简单,因为复杂的别人做了,所以才会觉得简单.我们先梳理一下服务的分类,首先有本地服务跟系统服务的区分,而在APP里写的服务大多就成为Java服务或者应用服务. /*************************************************************************

Android native应用开发简明教程 (1) - 本地开发武器库概览

Android本地开发武器库概览 Android本地开发支持简史 Android 1.0的时代,没有提供对于C/C++开发本地Android代码的支持,尽管Android系统本身使用了大量的C++做底层开发. 第一个里程碑 - 支持jni开发so库 (Android 1.5) Android第一次支持本地开发是在Android 1.5版本,对应Android API level 3.这一版本,有了正式的Android NDK的支持,可以通过jni写so库的方式,供Android应用来调用. An

Android native应用开发简明教程 (2) - 本地应用的原理

本地应用原理 从NativeActivity说起 本地App,本质上是一个Java App调用了一个JNI的库,而应用的逻辑通过native代码来实现. NativeActivity是继承自Activity的一个类,代码在:/frameworks/base/core/java/android/app/NativeActivity.java中: public class NativeActivity extends Activity implements SurfaceHolder.Callbac

修改android最小堆内存

在oncreate的时候加入如下代码段即可保证该运行程序有足够的内存了: [java] view plaincopy int CWJ_HEAP_SIZE = 10 * 1024 * 1024;  //10M的内存   VMRuntime.getRuntime().setMinimumHeapSize(CWJ_HEAP_SIZE);   别忘了导入包: [java] view plaincopy import dalvik.system.VMRuntime;   深层理解,进入andorid源码内

Android图片加载库Fresco

在Android设备上面,快速高效的显示图片是极为重要的.过去的几年里,我们在如何高效的存储图像这方面遇到了很多问题.图片太大,但是手机的内存却很小.每一个像素的R.G.B和alpha通道总共要占用4byte的空间.如果手机的屏幕是480*800,那么一张屏幕大小的图片就要占用1.5M的内存.手机的内存通常很小,特别是Android设备还要给各个应用分配内存.在某些设备上,分给Facebook App的内存仅仅有16MB.一张图片就要占据其内存的十分之一. 当你的App内存溢出会发生什么呢?它当

android开发性能分析

1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜一堆关于性能的建议,感觉大家你一总结.我一总结的都说到了很多优化注意事项,但是看过这些文章后大多数存在一个问题就是只给出啥啥啥不能用,啥啥啥该咋用等,却很少有较为系统的进行真正性能案例分析的,大多数都是嘴上喊喊或者死记住规则而已(当然了,这话我自己听着都有些刺耳,实在不好意思,其实关于性能优化的优质博文网上也还是有很多的,譬如Google官方都已经推出了优化专题,我这里只是总结下自的感悟而已,若有得罪欢迎拍砖,我

Android 代码性能优化建议

这篇文章主要介绍一些小细节的优化技巧,当这些小技巧综合使用起来的时候,对于整个App的性能提升还是有作用的,只是不能较大幅度的提升性能而已.选择合适的算法与数据结构才应该是你首要考虑的因素,在这篇文章中不会涉及这方面.你应该使用这篇文章中的小技巧作为平时写代码的习惯,这样能够提升代码的效率. 通常来说,高效的代码需要满足下面两个规则: 不要做冗余的工作 如果能避免,尽量不要分配内存 在优化App时最难解决的问题之一就是让App能在各种类型的设备上运行.不同版本的虚拟机在不同的处理器上会有不同的运