您的位置:首页 > 编程语言

代码里打印程序所占用的内存

2014-07-19 02:37 375 查看
转自:http://www.2cto.com/kf/201308/233840.html



Activity Monitor是能如实反应程序实际所占用内存的实时变化情况。 但是在这种模式下,我觉得自己不能看到控制台所打印的日志, 总而言之, 上面的这种查看程序内存的方法没有问题,

但是如果你想在控制台里面打印出来程序所占用的内存,也可使用如下方法:

void report_memory(void)

{

struct task_basic_info info;

mach_msg_type_number_t size = sizeof(info);

kern_return_t kerr = task_info(mach_task_self(),

TASK_BASIC_INFO,

(task_info_t)&info,

&size);

if( kerr == KERN_SUCCESS )

{

//printf("Memory vm : %u\n",info.virtual_size);

//printf("Memory in use (in bytes): %u b\n", info.resident_size);

//printf("Memory in use (in k-bytes): %f k\n", info.resident_size / 1024.0);

printf("Memory in use (in m-bytes): %f m\n", info.resident_size / (1024.0 * 1024.0));

}

else

{

printf("Error with task_info(): %s\n", mach_error_string(kerr));

}

}

记得在引入头文件:

#import <mach/mach.h>

如果想在整个程序内直接调用这个方法, 可以在*-Prefix.pch文件里引入声明:

#ifdef __OBJC__

#import <UIKit/UIKit.h>

#import <Foundation/Foundation.h>

#endif

extern void report_memory(void);

在你想打印内存的地方可以直接调用此方法:

- (void)viewDidLoad

{

[super viewDidLoad];

////你的逻辑代码。。。。

report_memory();

}

下面是控制台里打印出来的内存。(来自模拟器)

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐