Android Dalvik VM内存优化之内存查看篇。
前序:
Android采用Java语言(虽然官方认定Kotlin语言为新语言,目前已经替换中),而Java语言虚拟机为JVM,但是,Android的虽然使用Java语言,但是虚拟机是Dalvik VM (此需要明确,下面需要用到此观点)。
Android内存优化:
1、Android内存和CPU使用情况。
2、Android的内存泄露。
3、
1、查看Android内存和CPU使用情况。
1.1:利用ActivityManager可以查看可用内存,例如下面的代码:
ActivityManager am = (ActivityManager) this.getSystemService(Context.ACTIVITY_SERVICE);
ActivityManager.MemoryInfo memoryInfo = new ActivityManager.MemoryInfo();
am.getMemoryInfo(memoryInfo);
long totalMem = memoryInfo.totalMem;
long availMem = memoryInfo.availMem;
boolean isLowMemory = memoryInfo.lowMemory;
long threshold = memoryInfo.threshold;
Log.e(KEY_TAG, "======== 当前进程总共的内存量:" + totalMem + "b");
Log.e(KEY_TAG, "======== 当前进程可用的空闲内存量:" + availMem + "b");
Log.e(KEY_TAG, "======== 当前进程是否处于低内存状态:" + isLowMemory + "b");
Log.e(KEY_TAG, "======== 当前进程是否处于低内存状态的阈值:" + threshold+"b");
1.2:利用Android.os.Debug来查询PSS、VSS和USS等单个进程使用内存信息。
Debug.MemoryInfo debugInfo = new Debug.MemoryInfo();
Debug.getMemoryInfo(debugInfo);
int privateDirty = debugInfo.getTotalPrivateDirty();//获取USS数据。
int totalPss = debugInfo.getTotalPss();//获取PSS数据。
int sharedDirty = debugInfo.getTotalSharedDirty();//获取RSS数据。
Log.e(KEY_TAG, "========= 当前进程独占的物理内存的内存量:" + privateDirty + "kb");
Log.e(KEY_TAG, "========= 当前进程实际的物理内存包含共享内存库占用的内存量:" + sharedDirty + "kb");
Log.e(KEY_TAG, "========= 当前进程实际的物理内存包含比例分配共享库占用的内存量:" + totalPss + "kb");
VSS:是Virtual Set Size的缩写,表示虚拟耗用内存(包含共享库占用的内存)。
RSS:是Resident Set Size的缩写,实际使用物理内存(包含共享库占用的内存)。
PSS:是Proportional Set Size的缩写,实际使用的物理内存(比例分配共享库占用的内
存)。
USS:是Unique Set Size的缩写,进程独自占用的物理内存(不包含共享库占用的内
存)。
一般来说,内存占用大小有如下规律。
VSS >= RSS >= PSS >= USS.
1.3:Google为开发人员提供了一个专用工具DDMS,通过此工具可以获取内存的使用
状况。
DDMS的全称是Dalvik Debug Monitor Service, 他提供了如下所示的功能。
1、为测试设备截屏。
2、针对特定的进程查看正在运行的线程以及堆信息。
3、Logcat.
4、广播状态信息。
5、模拟电话呼叫等等。
1.4:可以通过手机上进行查看内存状态。