文档章节

优化的NSLog技巧

mahb520
 mahb520
发布于 2014/04/22 13:29
字数 321
阅读 35
收藏 0

使用NSLog的一个风险是:它的运行会占用时间和设备资源。

简单而粗暴的解决方案是:在release前,将所有的NSLog注释掉。简单有效,但副作用是:下次你要调试时,又得将NSLog一个个取消注释。


以release模式编译的程序不会用NSLog输出,而以debug模式编译的程序将执行NSLog的全部功能。


解决步骤:

  1. 修改<AppName>-Prefix.pch ,增加以下的宏代码

    [cpp] view plaincopy

    1. #ifdef DEBUG  

    2. # define DLog(fmt, ...) NSLog((@"[文件名:%s]\n" "[函数名:%s]\n" "[行号:%d] \n" fmt), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);  

    3. #else  

    4. # define DLog(...);  

    5. #endif  

  2. 在程序中使用DLog来替换原来的NSLog

    [cpp] view plaincopy


    1. DLog(@"当前程序目录是:%@", [self applicationDocumentsDirectory ]);  

  3. 修改项目的配置,使得在debug编译的时候,编译DLog的宏,产生详细的日志信息,而release的时候,不产生任何控制台输出
    在Other Linker Flags 中,在debug的时候,加入编译属性 -DEBUG

  4. 这样控制台会显示这样的日志信息

    [cpp] view plaincopy

    1. 2011-12-27 22:23:53.303 IManager[5449:b603] [文件名:/Users/roamer/Project/ÂõΩÊ≥∞ÂêõÂÆâ/Ëꕉ∏öÈÉ®ÁÆ°ÁêÜiphone/IManager/IManager/AppDelegate.m]  

    2. [函数名:-[AppDelegate application:didFinishLaunchingWithOptions:]]  

    3. [行号:37]   

    4. 当前程序目录是:/Users/roamer/Library/Application Support/iPhone Simulator/4.3.2/Applications/6B0E7B08-5528-468A-B728-0C4580805368/Documents  


本文转载自:http://blog.csdn.net/iosdevelopers/article/details/24271293

共有 人打赏支持
mahb520
粉丝 21
博文 73
码字总数 24908
作品 0
广州
项目经理
私信 提问
iOS NSLog调试技巧

xcode测试分为两种;一种是Debug,一种是Release.Debug是调试版本,包括的程序信息更多,运行速度慢;Release不包含任何调试信息,所以体积小,运行快. 因此,我们需要在这两种模式中切换,来确保N...

刘学良
2016/12/17
14
0
位移枚举解析

位移枚举 位移枚举是非常古老的 C 语言技巧 如果都是 1 结果就是1 如果都是 0 结果就是0 演练 定义枚举类型 /// 操作类型枚举typedef enum { ActionTypeTop = 1 << 0, ActionTypeBottom = 1...

就不穿小内
2015/12/11
106
0
GCD使用经验与技巧浅谈

前言 GCD(Grand Central Dispatch)可以说是Mac、iOS开发中的一大“利器”,本文就总结一些有关使用GCD的经验与技巧。 dispatchoncet必须是全局或static变量 这一条算是“老生常谈”了,但我认...

Snaiper
2015/10/21
61
0
iOS调试技巧总结

调试技巧总结   1.断点   1.1 普通断点   1.2 全局断点(Global BreakPoint)   1.3 条件断点(Condational Breakpoints) 2. 打印的艺术   2.1 NSLog   2.2 开启僵尸对象(Enable N...

AngusTing
2016/04/09
69
0
iOS开发技巧(系列十七:使用Xcode DEBUG模式和RELEASE模式)

在开发过程中,我们经常需要用到NSLog输出一些信息,甚至有的开发过程,必须在控制台查看输出,有经验的程序员通过控制台输出就能知道整个数据交互的一个流程。但是一个发布的程序,里面带有...

召唤攻城狮
2014/07/31
0
1

没有更多内容

加载失败,请刷新页面

加载更多

Kafka+Flink 实现准实时异常检测系统

1.背景介绍 异常检测可以定义为“基于行动者(人或机器)的行为是否正常作出决策”,这项技术可以应用于非常多的行业中,比如金融场景中做交易检测、贷款检测;工业场景中做生产线预警;安防...

架构师springboot
42分钟前
6
0
DecimalFormat 类基本使用

/* * DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度 * 0 表示如果位数不足则以 0 填充 * # 表示只要有可能就把数字拉上这个位置 * */ public static void main(String[] args){...

嘴角轻扬30
59分钟前
4
0
This APT has Super Cow Powers.

在Debian/Ubuntu上,apt包管理器内嵌着一个彩蛋. 如果你在命令行界面输入 apt help 在最后一行能找到This APT has Super Cow Powers. 说明该apt具有超级牛力 牛力是个什么梗? 则说明你的系统...

taadis
今天
3
0
起薪2万的爬虫工程师,Python需要学到什么程度才可以就业?

爬虫工程师的的薪资为20K起,当然,因为大数据,薪资也将一路上扬。那么,Python需要学到什么程度呢?今天我们来看看3位前辈的回答。 1、前段时间快要毕业,而我又不想找自己的老本行Java开发...

糖宝lsh
今天
10
0
携手开发者共建云生态 首届腾讯云+社区开发者大会在京举办

本文由云+社区发表 北京时间12月15日,由腾讯云主办,极客邦科技、微信、腾讯TEG协办的首届腾讯云+社区开发者大会在北京朝阳悠唐皇冠假日酒店举办。在会上,腾讯云发布了重磅产品开发者平台以...

腾讯云加社区
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部