Android 如何獲取手機(jī)總內(nèi)存和可用內(nèi)存等信息
在android開(kāi)發(fā)中,有時(shí)候我們想獲取手機(jī)的一些硬件信息,比如android手機(jī)的總內(nèi)存和可用內(nèi)存大小。
這個(gè)該如何實(shí)現(xiàn)呢?
通過(guò)讀取文件"/proc/meminfo"的信息能夠獲取手機(jī)Memory的總量,而通過(guò)ActivityManager.getMemoryInfo(ActivityManager.MemoryInfo)方法可以獲取當(dāng)前的可用Memory量。
"/proc/meminfo"文件記錄了android手機(jī)的一些內(nèi)存信息,在命令行窗口里輸入"adb shell",進(jìn)入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
#
下面先對(duì)"/proc/meminfo"文件里列出的字段進(jìn)行粗略解釋:
MemTotal: 所有可用RAM大小。
MemFree: LowFree與HighFree的總和,被系統(tǒng)留著未使用的內(nèi)存。
Buffers: 用來(lái)給文件做緩沖大小。
Cached: 被高速緩沖存儲(chǔ)器(cache memory)用的內(nèi)存的大?。ǖ扔赿iskcache minus SwapCache)。
SwapCached:被高速緩沖存儲(chǔ)器(cache memory)用的交換空間的大小。已經(jīng)被交換出來(lái)的內(nèi)存,仍然被存放在swapfile中,用來(lái)在需要的時(shí)候很快的被替換而不需要再次打開(kāi)I/O端口。
Active: 在活躍使用中的緩沖或高速緩沖存儲(chǔ)器頁(yè)面文件的大小,除非非常必要,否則不會(huì)被移作他用。
Inactive: 在不經(jīng)常使用中的緩沖或高速緩沖存儲(chǔ)器頁(yè)面文件的大小,可能被用于其他途徑。
SwapTotal: 交換空間的總大小。
SwapFree: 未被使用交換空間的大小。
Dirty: 等待被寫回到磁盤的內(nèi)存大小。
Writeback: 正在被寫回到磁盤的內(nèi)存大小。
AnonPages:未映射頁(yè)的內(nèi)存大小。
Mapped: 設(shè)備和文件等映射的大小。
Slab: 內(nèi)核數(shù)據(jù)結(jié)構(gòu)緩存的大小,可以減少申請(qǐng)和釋放內(nèi)存帶來(lái)的消耗。
SReclaimable:可收回Slab的大小。
SUnreclaim:不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)。
PageTables:管理內(nèi)存分頁(yè)頁(yè)面的索引表的大小。
NFS_Unstable:不穩(wěn)定頁(yè)表的大小。
要獲取android手機(jī)總內(nèi)存大小,只需讀取"/proc/meminfo"文件的第1行,并進(jìn)行簡(jiǎn)單的字符串處理即可。
下面直接給出詳細(xì)步驟,大家可以根據(jù)實(shí)際情況進(jìn)行相應(yīng)擴(kuò)展。
1.新建項(xiàng)目,修改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當(dāng)前可用內(nèi)存大小
ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
MemoryInfo mi = new MemoryInfo();
am.getMemoryInfo(mi);
//mi.availMem; 當(dāng)前系統(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或者M(jìn)B,內(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("手機(jī)總內(nèi)存: " + this.getTotalMemory() + ", " + "可用內(nèi)存: "
+ this.getAvailMemory());
}
}
大功告成,順利讀取android手機(jī)的總內(nèi)存和當(dāng)前的可用內(nèi)存。這里只是拋磚引玉,大家可以舉一反三,進(jìn)行擴(kuò)展。當(dāng)然我們還可以通過(guò)讀取"/proc/cupinfo"來(lái)獲取android手機(jī)的CPU參數(shù),通過(guò)讀取"/proc/stat"文件來(lái)計(jì)算CPU的使用率,這里不再贅述。
第二種方法:手用java的反射機(jī)制來(lái)獲取手機(jī)的內(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();
}
}
}
以上就是對(duì) Android 獲取內(nèi)存信息的資料整理,做這塊Android開(kāi)發(fā)的朋友可以看下。
- Android獲取SD卡路徑及SDCard內(nèi)存的方法
- 解析Android獲取系統(tǒng)cpu信息,內(nèi)存,版本,電量等信息的方法詳解
- Android 異步獲取網(wǎng)絡(luò)圖片并處理導(dǎo)致內(nèi)存溢出問(wèn)題解決方法
- Android實(shí)現(xiàn)獲取SD卡總?cè)萘?,可用大小,機(jī)身內(nèi)存總?cè)萘考翱捎么笮〉姆椒?/a>
- android實(shí)用工具類分享(獲取內(nèi)存/檢查網(wǎng)絡(luò)/屏幕高度/手機(jī)分辨率)
- Android獲取設(shè)備CPU核數(shù)、時(shí)鐘頻率以及內(nèi)存大小的方法
- android不讀入內(nèi)存獲取圖像寬高信息的方法
- android 獲取手機(jī)內(nèi)存及 內(nèi)存可用空間的方法
- Android獲取App內(nèi)存使用情況的方法
- Android獲取系統(tǒng)儲(chǔ)存以及內(nèi)存信息的方法(一)
相關(guān)文章
Android編程實(shí)現(xiàn)對(duì)電池狀態(tài)的監(jiān)視功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)對(duì)電池狀態(tài)的監(jiān)視功能,涉及Android基于廣播實(shí)現(xiàn)針對(duì)電源電量的判定與監(jiān)視技巧,需要的朋友可以參考下2016-11-11
Android開(kāi)發(fā)實(shí)現(xiàn)文件關(guān)聯(lián)方法介紹
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)文件關(guān)聯(lián)方法介紹,具有一定參考價(jià)值,需要的朋友樂(lè)意了解下。2017-10-10
android studio 的下拉菜單Spinner使用詳解
這篇文章主要介紹了android studio 的下拉菜單Spinner使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Android編程實(shí)現(xiàn)的首頁(yè)左右滑動(dòng)切換功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)的首頁(yè)左右滑動(dòng)切換功能,涉及Android事件監(jiān)聽(tīng)及響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2017-07-07
解決Android BitmapFactory的基本使用問(wèn)題
很多朋友給小編反饋使用方法BitmapFactory.decodeFile轉(zhuǎn)化Bitmap時(shí)報(bào)錯(cuò),究竟是什么原因?qū)е洛e(cuò)誤問(wèn)題呢?今天通過(guò)本文給大家介紹下解決Android BitmapFactory的基本使用問(wèn)題,感興趣的朋友一起看看吧2021-10-10
Android自定義View實(shí)現(xiàn)簡(jiǎn)單的圓形Progress效果
這篇文章主要介紹了Android自定義View實(shí)現(xiàn)簡(jiǎn)單的圓形Progress效果的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
Android 開(kāi)機(jī)直接運(yùn)行app并當(dāng)做手機(jī)桌面的實(shí)例
今天小編就為大家分享一篇Android 開(kāi)機(jī)直接運(yùn)行app并當(dāng)做手機(jī)桌面的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
Android實(shí)現(xiàn)自定義加載框的代碼示例
本篇文章主要介紹了Android實(shí)現(xiàn)自定義加載框的代碼示例,App在與服務(wù)器進(jìn)行網(wǎng)絡(luò)交互的時(shí)候,有個(gè)提示加載框,有興趣的可以了解一下。2017-02-02

