Android 如何獲取手機總內(nèi)存和可用內(nèi)存等信息
在android開發(fā)中,有時候我們想獲取手機的一些硬件信息,比如android手機的總內(nèi)存和可用內(nèi)存大小。
這個該如何實現(xiàn)呢?
通過讀取文件"/proc/meminfo"的信息能夠獲取手機Memory的總量,而通過ActivityManager.getMemoryInfo(ActivityManager.MemoryInfo)方法可以獲取當前的可用Memory量。
"/proc/meminfo"文件記錄了android手機的一些內(nèi)存信息,在命令行窗口里輸入"adb shell",進入shell環(huán)境,輸入"cat /proc/meminfo"即可在命令行里顯示meminfo文件的內(nèi)容
具體如下所示。
C:\Users\Figo>adb shell
# cat /proc/meminfo
cat /proc/meminfo
MemTotal: 94096 kB
MemFree: 1684 kB
Buffers: 16 kB
Cached: 27160 kB
SwapCached: 0 kB
Active: 35392 kB
Inactive: 44180 kB
Active(anon): 26540 kB
Inactive(anon): 28244 kB
Active(file): 8852 kB
Inactive(file): 15936 kB
Unevictable: 280 kB
Mlocked: 0 kB
SwapTotal: 0 kB
SwapFree: 0 kB
Dirty: 0 kB
Writeback: 0 kB
AnonPages: 52688 kB
Mapped: 17960 kB
Slab: 3816 kB
SReclaimable: 936 kB
SUnreclaim: 2880 kB
PageTables: 5260 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 47048 kB
Committed_AS: 1483784 kB
VmallocTotal: 876544 kB
VmallocUsed: 15456 kB
VmallocChunk: 829444 kB
#
下面先對"/proc/meminfo"文件里列出的字段進行粗略解釋:
MemTotal: 所有可用RAM大小。
MemFree: LowFree與HighFree的總和,被系統(tǒng)留著未使用的內(nèi)存。
Buffers: 用來給文件做緩沖大小。
Cached: 被高速緩沖存儲器(cache memory)用的內(nèi)存的大?。ǖ扔赿iskcache minus SwapCache)。
SwapCached:被高速緩沖存儲器(cache memory)用的交換空間的大小。已經(jīng)被交換出來的內(nèi)存,仍然被存放在swapfile中,用來在需要的時候很快的被替換而不需要再次打開I/O端口。
Active: 在活躍使用中的緩沖或高速緩沖存儲器頁面文件的大小,除非非常必要,否則不會被移作他用。
Inactive: 在不經(jīng)常使用中的緩沖或高速緩沖存儲器頁面文件的大小,可能被用于其他途徑。
SwapTotal: 交換空間的總大小。
SwapFree: 未被使用交換空間的大小。
Dirty: 等待被寫回到磁盤的內(nèi)存大小。
Writeback: 正在被寫回到磁盤的內(nèi)存大小。
AnonPages:未映射頁的內(nèi)存大小。
Mapped: 設備和文件等映射的大小。
Slab: 內(nèi)核數(shù)據(jù)結(jié)構(gòu)緩存的大小,可以減少申請和釋放內(nèi)存帶來的消耗。
SReclaimable:可收回Slab的大小。
SUnreclaim:不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)。
PageTables:管理內(nèi)存分頁頁面的索引表的大小。
NFS_Unstable:不穩(wěn)定頁表的大小。
要獲取android手機總內(nèi)存大小,只需讀取"/proc/meminfo"文件的第1行,并進行簡單的字符串處理即可。
下面直接給出詳細步驟,大家可以根據(jù)實際情況進行相應擴展。
1.新建項目,修改main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:textStyle="bold" android:id="@+id/system_memory" /> </LinearLayout>
2.完善ReadSystemMemory.java類
package com.figo.readsyememory; import android.app.Activity; import android.os.Bundle; import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; import android.app.ActivityManager; import android.app.ActivityManager.MemoryInfo; import android.content.Context; import android.text.format.Formatter; import android.util.Log; import android.widget.TextView; public class ReadSystemMemory extends Activity { TextView tv = null; private String getAvailMemory() {// 獲取android當前可用內(nèi)存大小 ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE); MemoryInfo mi = new MemoryInfo(); am.getMemoryInfo(mi); //mi.availMem; 當前系統(tǒng)的可用內(nèi)存 return Formatter.formatFileSize(getBaseContext(), mi.availMem);// 將獲取的內(nèi)存大小規(guī)格化 } private String getTotalMemory() { String str1 = "/proc/meminfo";// 系統(tǒng)內(nèi)存信息文件 String str2; String[] arrayOfString; long initial_memory = 0; try { FileReader localFileReader = new FileReader(str1); BufferedReader localBufferedReader = new BufferedReader( localFileReader, 8192); str2 = localBufferedReader.readLine();// 讀取meminfo第一行,系統(tǒng)總內(nèi)存大小 arrayOfString = str2.split("\\s+"); for (String num : arrayOfString) { Log.i(str2, num + "\t"); } initial_memory = Integer.valueOf(arrayOfString[1]).intValue() * 1024;// 獲得系統(tǒng)總內(nèi)存,單位是KB,乘以1024轉(zhuǎn)換為Byte localBufferedReader.close(); } catch (IOException e) { } return Formatter.formatFileSize(getBaseContext(), initial_memory);// Byte轉(zhuǎn)換為KB或者MB,內(nèi)存大小規(guī)格化 } /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); tv = (TextView) findViewById(R.id.system_memory); tv.setText("手機總內(nèi)存: " + this.getTotalMemory() + ", " + "可用內(nèi)存: " + this.getAvailMemory()); } }
大功告成,順利讀取android手機的總內(nèi)存和當前的可用內(nèi)存。這里只是拋磚引玉,大家可以舉一反三,進行擴展。當然我們還可以通過讀取"/proc/cupinfo"來獲取android手機的CPU參數(shù),通過讀取"/proc/stat"文件來計算CPU的使用率,這里不再贅述。
第二種方法:手用java的反射機制來獲取手機的內(nèi)存的一些信息。
public class GetFreeMem extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); Method _readProclines = null; try { Class procClass; procClass = Class.forName("android.os.Process"); Class parameterTypes[]= new Class[] {String.class, String[].class, long[].class }; _readProclines = procClass.getMethod("readProcLines", parameterTypes); Object arglist[] = new Object[3]; final String[] mMemInfoFields = new String[] {"MemTotal:", "MemFree:", "Buffers:", "Cached:"}; long[] mMemInfoSizes = new long[mMemInfoFields.length]; mMemInfoSizes[0] = 30; mMemInfoSizes[1] = -30; arglist[0] = new String("/proc/meminfo"); arglist[1] = mMemInfoFields; arglist[2] = mMemInfoSizes; if(_readProclines!=null){ _readProclines.invoke(null, arglist); for (int i=0; i<mMemInfoSizes.length; i++) { Log.d("GetFreeMem", mMemInfoFields[i]+" : "+mMemInfoSizes[i]/1024); } } } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SecurityException e) { e.printStackTrace(); } catch (IllegalArgumentException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (InvocationTargetException e) { e.printStackTrace(); } catch (NoSuchMethodException e) { e.printStackTrace(); } } }
以上就是對 Android 獲取內(nèi)存信息的資料整理,做這塊Android開發(fā)的朋友可以看下。
- Android獲取SD卡路徑及SDCard內(nèi)存的方法
- 解析Android獲取系統(tǒng)cpu信息,內(nèi)存,版本,電量等信息的方法詳解
- Android 異步獲取網(wǎng)絡圖片并處理導致內(nèi)存溢出問題解決方法
- Android實現(xiàn)獲取SD卡總?cè)萘?,可用大小,機身內(nèi)存總?cè)萘考翱捎么笮〉姆椒?/a>
- android實用工具類分享(獲取內(nèi)存/檢查網(wǎng)絡/屏幕高度/手機分辨率)
- Android獲取設備CPU核數(shù)、時鐘頻率以及內(nèi)存大小的方法
- android不讀入內(nèi)存獲取圖像寬高信息的方法
- android 獲取手機內(nèi)存及 內(nèi)存可用空間的方法
- Android獲取App內(nèi)存使用情況的方法
- Android獲取系統(tǒng)儲存以及內(nèi)存信息的方法(一)
相關(guān)文章
Flutter使用sqflite處理數(shù)據(jù)表變更的方法詳解
了解過數(shù)據(jù)庫的同學應該會知道,數(shù)據(jù)表結(jié)構(gòu)是可能發(fā)生改變的。所以本文為大家介紹了Flutter?使用?sqflite?處理數(shù)據(jù)表變更的版本升級處理方法,感興趣的可以了解一下2023-04-04Android開發(fā)中PopupWindow用法實例分析
這篇文章主要介紹了Android開發(fā)中PopupWindow用法,結(jié)合實例形式分析了PopupWindow彈出窗口效果的使用技巧,需要的朋友可以參考下2016-02-02android2.3.5 CDMA/EVDO撥號APN解決方案
google提供的android2.3里面,只能在GSM/WCDMA情況下才能從“設置”->“無線和網(wǎng)絡”->“移動網(wǎng)絡”->“接入點名稱”中選擇不同的apn帳號進行撥號連接,而CDMA/EVDO則沒有這個功能,接下來本文介紹一些方法實現(xiàn)這個功能,感興趣的朋友可以了解下2013-01-01Android編程連接MongoDB及增刪改查等基本操作示例
這篇文章主要介紹了Android編程連接MongoDB及增刪改查等基本操作,簡單介紹了MongoDB功能、概念、使用方法及Android操作MongoDB數(shù)據(jù)庫的基本技巧,需要的朋友可以參考下2017-07-07Android中MPAndroidChart自定義繪制最高點標識的方法
目前在做一款軟件,要求在展示走勢圖的時候?qū)ψ罡唿c進行自定義繪制,下面這篇文章主要給大家介紹了關(guān)于Android中MPAndroidChart自定義繪制最高點標識的方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。2018-03-03Android深入探究自定義View之嵌套滑動的實現(xiàn)
什么是嵌套滑動?當我們向下滑動時,首先是外部的布局向下滑動,然后才是內(nèi)部的RecyclerView滑動,向上滑動也是如此。這就是嵌套滑動的效果2021-11-11