zoukankan      html  css  js  c++  java
  • NSLog使用小记

    原文链接:http://luoyl.info/blog/2012/05/nslog-tips/

    在程序开发中,我们需要经常需要实时输出一些运行数据来判断程序是否正确的运行,在IOS开发中,NSLog很像printf和println,会在控制台里面格式化的输出结果。使用NSLog输出,对应不同的对象需要用不同的格式化字符,NSLog的格式如下所示:

    1. %@        对象    
    2. %d, %i   整数    
    3. %u         无符整形    
    4. %f           浮点/双字    
    5. %x, %X  二进制整数    
    6. %o         八进制整数    
    7. %zu       size_t    
    8. %p        指针    
    9. %e        浮点/双字 (科学计算)
    10. %g        浮点/双字    
    11. %s        C字符串    
    12. %.*s     Pascal字符串    
    13. %c       字符    
    14. %C      unichar    
    15. %lld     64位长整数(long long)    
    16. %llu     无符64位长整数    
    17. %Lf      64位双字  

    在release版本禁止输出NSLog内容

    因为NSLog的输出还是比较消耗系统资源的,而且输出的数据也可能会暴露出App里的保密数据,所以发布正式版时需要把这些输出全部屏蔽掉。

    我们可以在发布版本前先把所有NSLog语句注释掉,等以后要调试时,再取消这些注释,这实在是一件无趣而耗时的事!还好,还有更优雅的解决方法,就是在项目的prefix.pch文件里加入下面一段代码,加入后,NSLog就只在Debug下有输出,Release下不输出了。

    1. #ifndef __OPTIMIZE__   
    2. #define NSLog(...) NSLog(__VA_ARGS__)   
    3. #else   
    4. #define NSLog(...) {}   
    5. #endif  

    如我项目里的prefix.pch文件:

      1. #ifndef __IPHONE_4_0   
      2. #warning "This project uses features only available in iOS SDK 4.0 and later."   
      3. #endif   
      4.   
      5. #ifdef __OBJC__   
      6.     #import <UIKit/UIKit.h>   
      7.     #import <Foundation/Foundation.h>   
      8.     #import "AppDelegate.h"   
      9.     #import "UIViewController+Customized.h"   
      10. #endif   
      11.   
      12. #ifndef __OPTIMIZE__   
      13. #define NSLog(...) NSLog(__VA_ARGS__)   
      14. #else   
      15. #define NSLog(...) {}   
      16. #endif  
  • 相关阅读:
    0621回顾与总结
    0614--演示
    学习进度条
    实验四主存空间的分配和回收
    学术诚信和职业道德
    《构建之法》读第六、第七章有感
    0422 Step2-FCFS调度
    java 版的复利计算器(张俊毅 周修文)
    复利程序(c语言)(张俊毅 周修文)
    《构建之法》第4章
  • 原文地址:https://www.cnblogs.com/celestial/p/2541259.html
Copyright © 2011-2022 走看看