From: http://www.android-study.com/pingtaikaifa/68.html
第一种方法:
在Android开发中,我们有时候需要获取手机的一些硬件信息,比如android手机的可用内存和总内存,那么这个该如何实现呢?
通过读取文件"/proc/meminfo"的信息能够获取手机Memory的总量,而通过ActivityManager.getMemoryInfo(ActivityManager.MemoryInfo)方法可以获取当前的可用Memory量。
"/proc/meminfo"文件记录了android手机的一些内存信息,在命令行窗口里输入"adb shell",进入shell环境,输入"cat /proc/meminfo"即可在命令行里显示meminfo文件的内容,具体如下所示。
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: 所有可用内存大小。
MemFree: LowFree与HighFree的总和,被系统留着未使用的内存。
Buffers: 用来给文件做缓冲大小。
Cached: 被高速缓冲存储器(cache memory)用的内存的大小(等于diskcache minus SwapCache)。
SwapCached:被高速缓冲存储器(cache memory)用的交换空间的大小。已经被交换出来的内存,仍然被存放在swapfile中,用来在需要的时候很快的被替换而不需要再次打开I/O端口。
Active: 在活跃使用中的缓冲或高速缓冲存储器页面文件的大小,除非非常必要,否则不会被移作他用。
Inactive: 在不经常使用中的缓冲或高速缓冲存储器页面文件的大小,可能被用于其他途径。
SwapTotal: 交换空间的总大小。
SwapFree: 未被使用交换空间的大小。
Dirty: 等待被写回到磁盘的内存大小。
Writeback: 正在被写回到磁盘的内存大小。
AnonPages:未映射页的内存大小。
Mapped: 设备和文件等映射的大小。
Slab: 内核数据结构缓存的大小,可以减少申请和释放内存带来的消耗。
SReclaimable:可收回Slab的大小。
SUnreclaim:不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)。
PageTables:管理内存分页页面的索引表的大小。
NFS_Unstable:不稳定页表的大小。
要获取android手机总内存大小,只需读取"/proc/meminfo"文件的第1行,并进行简单的字符串处理即可。
下面直接给出详细步骤,大家可以根据实际情况进行相应扩展。
第一步:新建一个Android工程,命名为ReadSystemMemory,如下图所示。
第三步:完善ReadSystemMemory类,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
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可用内存大小
ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
MemoryInfo mi =
new
MemoryInfo();
am.getMemoryInfo(mi);
//mi.availMem; 当前系统的可用内存
return
Formatter.formatFileSize(getBaseContext(), mi.availMem);
// 将获取的内存大小规格化
}
private
String getTotalMemory() {
String str1 =
"/proc/meminfo"
;
// 系统内存信息文件
String str2;
String[] arrayOfString;
long
initial_memory =
0
;
try
{
FileReader localFileReader =
new
FileReader(str1);
BufferedReader localBufferedReader =
new
BufferedReader(
localFileReader,
8192
);
str2 = localBufferedReader.readLine();
// 读取meminfo第一行,系统总内存大小
arrayOfString = str2.split(
"//s+"
);
for
(String num : arrayOfString) {
Log.i(str2, num +
"/t"
);
}
initial_memory = Integer.valueOf(arrayOfString[
1
]).intValue() *
1024
;
// 获得系统总内存,单位是KB,乘以1024转换为Byte
localBufferedReader.close();
}
catch
(IOException e) {
}
return
Formatter.formatFileSize(getBaseContext(), initial_memory);
// Byte转换为KB或者MB,内存大小规格化
}
/** 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(
"总内存: "
+
this
.getTotalMemory()+
","
+
"可用内存: "
+
this
.getAvailMemory());
}
}
|
第四步:运行该工程,结果如下:
Android获取手机内存成功,我们顺利的读取到了Android手机的总内存和当前的可用内存。当然我们还可以通过读取"/proc/cupinfo"来获取android手机的CPU参数,通过读取"/proc/stat"文件来计算CPU的使用率,这里只是抛砖引玉,大家可以举一反三,进行扩展。
第二种方法:
是在一个论坛里找到的,是一个高手用java的反射机制来获取手机的内存的一些信息。
具体代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
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();
}
}
}
|
效果如图: