打印IOS设备内存使用情况
来源:互联网 发布:svm算法推荐 编辑:程序博客网 时间:2024/04/30 08:34
由于iPhone这类移动设备内存有限,而又不能使用交换区,为了不至于导致内存不足而引起运行效率降低或应用崩溃,有时候需要获取当前的内存状况,以决定采用的缓存策略。
不过iOS SDK文档里并没有提及这种底层的API,于是我搜了一番,找到了host_statistics()这个函数。
BOOL memoryInfo(vm_statistics_data_t *vmStats) {
mach_msg_type_number_t infoCount = HOST_VM_INFO_COUNT;
kern_return_t kernReturn = host_statistics(mach_host_self(), HOST_VM_INFO, (host_info_t)vmStats, &infoCount);
return kernReturn == KERN_SUCCESS;
}
void logMemoryInfo() {
vm_statistics_data_t vmStats;
if (memoryInfo(&vmStats)) {
NSLog(@"free: %u\nactive: %u\ninactive: %u\nwire: %u\nzero fill: %u\nreactivations: %u\npageins: %u\npageouts: %u\nfaults: %u\ncow_faults: %u\nlookups: %u\nhits: %u",
vmStats.free_count * vm_page_size,
vmStats.active_count * vm_page_size,
vmStats.inactive_count * vm_page_size,
vmStats.wire_count * vm_page_size,
vmStats.zero_fill_count * vm_page_size,
vmStats.reactivations * vm_page_size,
vmStats.pageins * vm_page_size,
vmStats.pageouts * vm_page_size,
vmStats.faults,
vmStats.cow_faults,
vmStats.lookups,
vmStats.hits
);
}
}
#include <mach/mach.h>
顺便再简要介绍下:free是空闲内存;active是已使用,但可被分页的(在iOS中,只有在磁盘上静态存在的才能被分页,例如文件的内存映射,而动态分配的内存是不能被分页的);inactive是不活跃的,也就是程序退出后却没释放的内存,以便加快再次启动,而当内存不足时,就会被回收,因此也可看作空闲内存;wire就是已使用,且不可被分页的。此外,这篇文档也有作介绍。
最后你会发现,即使把这些全加起来,也比设备内存少很多,那么剩下的只好当成已被占用的神秘内存了。不过在模拟器上,这4个加起来基本上就是Mac的物理内存量了,相差不到2MB。
而总物理内存可以用NSRealMemoryAvailable()来获取,这个函数不需要提供参数,文档里也有记载,我就不写演示代码了。
不过iOS SDK文档里并没有提及这种底层的API,于是我搜了一番,找到了host_statistics()这个函数。
参数虽然很多,但基本上都是固定的值,我也就不解释,直接上代码了:
BOOL memoryInfo(vm_statistics_data_t *vmStats) {
mach_msg_type_number_t infoCount = HOST_VM_INFO_COUNT;
kern_return_t kernReturn = host_statistics(mach_host_self(), HOST_VM_INFO, (host_info_t)vmStats, &infoCount);
return kernReturn == KERN_SUCCESS;
}
void logMemoryInfo() {
vm_statistics_data_t vmStats;
if (memoryInfo(&vmStats)) {
NSLog(@"free: %u\nactive: %u\ninactive: %u\nwire: %u\nzero fill: %u\nreactivations: %u\npageins: %u\npageouts: %u\nfaults: %u\ncow_faults: %u\nlookups: %u\nhits: %u",
vmStats.free_count * vm_page_size,
vmStats.active_count * vm_page_size,
vmStats.inactive_count * vm_page_size,
vmStats.wire_count * vm_page_size,
vmStats.zero_fill_count * vm_page_size,
vmStats.reactivations * vm_page_size,
vmStats.pageins * vm_page_size,
vmStats.pageouts * vm_page_size,
vmStats.faults,
vmStats.cow_faults,
vmStats.lookups,
vmStats.hits
);
}
}
调用memoryInfo()就能拿到内存信息了,它的类型是vm_statistics_data_t。这个结构体有很多字段,在logMemoryInfo()中展示了如何获取它们。注意这些字段大都是页面数,要乘以vm_page_size才能拿到字节数。
顺便再简要介绍下:free是空闲内存;active是已使用,但可被分页的(在iOS中,只有在磁盘上静态存在的才能被分页,例如文件的内存映射,而动态分配的内存是不能被分页的);inactive是不活跃的,也就是程序退出后却没释放的内存,以便加快再次启动,而当内存不足时,就会被回收,因此也可看作空闲内存;wire就是已使用,且不可被分页的。此外,这篇文档也有作介绍。
最后你会发现,即使把这些全加起来,也比设备内存少很多,那么剩下的只好当成已被占用的神秘内存了。不过在模拟器上,这4个加起来基本上就是Mac的物理内存量了,相差不到2MB。
而总物理内存可以用NSRealMemoryAvailable()来获取,这个函数不需要提供参数,文档里也有记载,我就不写演示代码了。
0 0
- 打印IOS设备内存使用情况
- iOS - 代码查看控制台打印内存使用情况:
- 获取ios内存使用情况
- 获取iOS内存使用情况
- 获取iOS内存使用情况
- 获取当前ios设备的内存使用情况,获取客户端ip地址
- 【IOS】IOS 获取当前内存使用情况
- 写出方法获取ios内存使用情况。
- 获取iOS内存的使用情况
- 写出方法获取ios内存使用情况
- 写出方法获取ios内存使用情况
- adb 打印终端中内存使用情况的方法
- adb 打印终端中内存使用情况的方法
- 关于iOS 设备贴图使用情况的说明
- ADB查看设备内存情况
- iOS 内存分区情况
- 使用代码跟踪iOS App的内存使用情况
- ios获取设备内存和应用使用内存
- 融云调用图片,通讯录和语音异常
- MySQL学习记录
- 浅析NGUITools.DestroyImmediate和NGUITools.Destroy的区别
- 处理大并发之 对epoll的理解,epoll客户端服务端代码
- 漏洞小知识概况
- 打印IOS设备内存使用情况
- 脑补原码、反码、补码
- 处理大并发之五 使用libevent利器bufferevent
- 在Activity中关闭另一个Activity
- React Native入门——环境配置及Hello World
- 四种数据持久化方法 iOS开发
- spinner 下拉列表
- dedecms中一个关于session的bug
- static {},static代码块地含义