iOS: #ifdef DEBUG

来源:互联网 发布:网络新闻发言人 编辑:程序博客网 时间:2024/06/04 19:15

以前改了个Log语句,在debug模式下输出NSLog, 发布之后不输出, 但是一直没有验证, 今天突发奇想, 就写了个demo验证了下,在发布环境的确是不会执行的!!
代码如下:

- (IBAction)testDebug:(UIButton *)sender {    NSString *message = @"DEBUG";#ifdef DEBUG    message = @"debug";#else    message = @"adhoc";#endif    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:message message:nil delegate:nil cancelButtonTitle:@"确定" otherButtonTitles: nil];    [alert show];    return;}


运行结果在debug模式下输出:debug

在发布环境输出:adhoc



开发时,经常用到NSLog,但release是又想一次过清掉all NSLog,方法是:在xxx-Prefix.pch里添加

[cpp] view plain copy
  1. #ifdef DEBUG  
  2. #    define DLog(...) NSLog(__VA_ARGS__)  
  3. #else  
  4. #    define DLog(...) /* */  
  5. #endif  
  6. #define ALog(...) NSLog(__VA_ARGS__)  

When you want to log only in debug builds use DLog(). In release builds DLog() will be compiled as an empty comment. Otherwise use ALog() for logging in both debug and release builds. (A as in always.)


那么"DEBUG"在哪里定义的呢? 在 "Target > Build Settings > Preprocessor Macros > Debug" 里有一个"DEBUG=1"。


你Run, Test, Analyze时,就属于debug mode,当Profile, Archive时就属于release mode。见你的ios project的"Edit Scheme..."


#ifdef DEBUG的另外一个用处是:用于push notification。sandbox device token and production device token一定不能mix在一起,否则就可能有些device收不到。见http://blog.csdn.net/totogogo/article/details/8035095


因此我们需要为reg device token准备2个url

[cpp] view plain copy
  1. #ifdef DEBUG  
  2.     NSString * const REG_URL=@"http://xxxx/reg_dev_token";  
  3. #else  
  4.     NSString * const REG_URL=@"http://xxxx/reg_production_token";  
  5. #endif  



0 0
原创粉丝点击