总的虚拟内存
这一个是在Mac OS X的棘手,因为它不使用预设的交换分区或文件如Linux。 这里有一个从苹果的文件项:
注:与大多数基于Unix的操作系统,Mac OS X中不使用虚拟内存的预分配的交换分区。相反,它使用的机器上的启动分区所有可用空间。
所以,如果你想知道多少虚拟内存仍然可用,你需要获得的根分区的大小。你可以这样说:
struct statfs stats;
if (0 == statfs("/", &stats))
{
myFreeSwap = (uint64_t)stats.f_bsize * stats.f_bfree;
}
总的虚拟目前使用
我还没有想出如何使目前的页数写来交换。
目前使用的虚拟内存我的过程
你可以处理你目前的统计信息使用的task_info功能。 这包括你的进程目前居民的大小和当前虚拟的大小。
struct task_basic_info t_info;
mach_msg_type_number_t t_info_count = TASK_BASIC_INFO_COUNT;
if (KERN_SUCCESS != task_info(mach_task_self(),
TASK_BASIC_INFO, (task_info_t)&t_info,
&t_info_count))
{
return -1;
}
// resident size is in t_info.resident_size;
// virtual size is in t_info.virtual_size;
共有内存可用
该系统的物理内存数量可以在可使用sysctl这样的系统功能:
#include <sys/types.h>
#include <sys/sysctl.h>
...
int64_t physical_memory;
mib[0] = CTL_HW;
mib[1] = HW_MEMSIZE;
length = sizeof(int64_t);
sysctl(mib, 2, &physical_memory, &length, NULL, 0);
目前使用的RAM
你可以从一般的统计记忆host_statistics系统的功能。
#include <mach/vm_statistics.h>
#include <mach/mach_types.h>
#include <mach/mach_init.h>
#include <mach/mach_host.h>
vm_size_t page_size;
mach_port_t mach_port;
mach_msg_type_number_t count;
vm_statistics_data_t vm_stats;
mach_port = mach_host_self();
count = sizeof(vm_stats) / sizeof(natural_t);
if (KERN_SUCCESS == host_page_size(mach_port, &page_size) &&
KERN_SUCCESS == host_statistics(mach_port, HOST_VM_INFO,
(host_info_t)&vm_stats, &count))
{
myFreeMemory = (int64_t)vm_stats.free_count * (int64_t)page_size;
used_memory = ((int64_t)vm_stats.active_count +
(int64_t)vm_stats.inactive_count +
(int64_t)vm_stats.wire_count) * (int64_t)page_size;
}
这里需要注意的一点是,有5个在Mac OS X的内存页类型,分别为:
- 有线内页被锁定到位,不能被交换
- 交换了积极的页面加载到物理内存,并会比较困难
- 不活跃的页是加载到内存,但没有使用最近甚至有可能不会在所有需要。 这些都是潜在的候选人交换。 这种存储器将可能需要被刷新。
- 缓存的网页,有一些被缓存如何有可能被重用。 快取记忆也许就不需要冲洗。 它仍然是有可能被重新缓存页面
- 免费的网页是完全免费的,随时可以使用。
这是很好地注意到,仅仅因为Mac OS X可能显示有时很少实际可用内存,它可能不会是花多少钱,准备好出应在短时间内使用。