Android工程模式下需要一个方便的途径去访问底层的硬件信息,以方便软件和测试同事更加简单的知道硬件信息;Android 从底层本质上说是 Linux,因此可以把 Android 当作 Linux 来访问,从而达到访问系统信息的目的;
参考文档:http://blog.csdn.net/bingqingsuimeng/article/details/7919397
一:proc 文件系统
proc 文件系统是Linux内核开发人员为了减少系统调用的复杂性而引入的一种特殊文件系统。
有了这种文件系统,用户只需要像查看文本文件一样就能够读取内核中的各种数据,给开发人员和系统管理员带来很大的便利。
很多Linux常用命令都是依靠分析/proc目录下的文件来运行的,比如 ls,ps 等。
1、读取CPU和内存等信息。
分析 /proc/cpuinfo 这个文件,就能获得 CPU信息。
adb shell
# cat /proc/cpuinfo
分析 /proc/meminfo ,就能获得内存信息
adb shell
# cat /proc/meminfo
adb shell
#cat proc/kmsg 抓取kernel抛出的调试信息
注:用 Android SDK 的 ActivityManager.getMemoryInfo(ActivityManager.MemoryInfo) 也能获得当前可用内存的大小
你如果使用Linux,可以看到 /proc目录还有很多文件,你可以用 man proc 命令来学习 proc 文件系统。
二:sysfs文件系统
linux 2.6 内核中引入了 sysfs 文件系统,是用户空间与内核空间进行交互的一个媒介。
比起古老的 proc 文件系统,它是基于内核的数据结构,因此组织结构上更加严密。
它的设计使内核的信息更易获取,而且更加清晰。内核空间与用户空间的映射关系如下表所示:
内核空间(internel) ——->用户空间(externel)
内核对象(kernel objects) ——->目录(directories)
对象属性(object attributes) ——->普通文件(regular files)
对象关系(object relationshiops) ——->符号链接(symbolic links)
先使用kobject_create_and_add() 創建目錄
再透過sysfs_create_group(example_kobj, &attr_group) 創建目录下的属性文件组, 其中 attr_group 是我们自己定义的属性相关文件,