代码里打印程序所占用的内存
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();
}
下面是控制台里打印出来的内存。(来自模拟器)
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();
}
下面是控制台里打印出来的内存。(来自模拟器)
相关文章推荐
- 如何在代码里打印程序所占用的内存
- iOS学习笔记11—代码里打印程序所占用的内存
- 怎么用代码里打印程序所占用的内存
- nios中优化代码和减少程序占用内存空间的设置方法
- 利用ajax,canvas实现的测试php程序占用内存的代码
- 控制台里打印程序所占用的内存
- Python以表格的形式打印占用内存Top10的程序列表
- 使用WorkingSet减少.net程序内存占用 转
- 我的asp.net程序当前占用了多少内存?
- 我的asp.net程序当前占用了多少内存?(转)
- C#查看程序占用系统的内存
- 我的asp.net程序当前占用了多少内存?
- 一个WinForm记事本程序(包含主/下拉/弹出菜单/打开文件/保存文件/打印/页面设置/字体/颜色对话框/剪切版操作等等控件用法以及记事本菜单事件/按键事件的具体代码)
- 一个WinForm记事本程序(包含主/下拉/弹出菜单/打开文件/保存文件/打印/页面设置/字体/颜色对话框/剪切版操作等等控件用法以及记事本菜单事件/按键事件的具体代码)
- 让你的AS3程序内存占用永远是人家程序的零头
- 如何得到程序运行时占用的内存?
- 一个WinForm记事本程序(包含主/下拉/弹出菜单/打开文件/保存文件/打印/页面设置/字体/颜色对话框/剪切版操作等等控件用法以及记事本菜单事件/按键事件的具体代码)
- ASP.NET 程序当前占用内存
- h264实时编解源代码,不仅有vfw,还有内存和cpu占用多少显示,vc6.0编译环境
- 我的asp.net程序当前占用了多少内存?