我正在做一个处理敏感信用卡数据的应用程序。

如果我的代码在调试模式下运行,我想将这些数据记录到控制台并进行一些文件转储。

然而,在最终的appstore版本(即当它运行在发布模式时),必须禁用所有这些(安全隐患)!

我会尽力回答我的问题;所以问题就变成了“这个解决方案是正确的还是最好的方法?”

// add `IS_DEBUG=1` to your debug build preprocessor settings  

#if( IS_DEBUG )  
#define MYLog(args...) NSLog(args)  
#else  
#define MYLog(args...)  
#endif  

当前回答

熊子韬的答案和我用的很接近;我还包括文件名(通过剥离file的路径)。

#ifdef DEBUG
    #define NSLogDebug(format, ...) \
    NSLog(@"<%s:%d> %s, " format, \
    strrchr("/" __FILE__, '/') + 1, __LINE__, __PRETTY_FUNCTION__, ## __VA_ARGS__)
#else
    #define NSLogDebug(format, ...)
#endif

其他回答

关于Swift的解决方案,请参考这个关于SO的帖子。

基本上Swift的解决方案是这样的:

#if DEBUG
    println("I'm running in DEBUG mode")
#else
    println("I'm running in a non-DEBUG mode")
#endif

此外,您还需要在Swift Compiler - Custom Flags部分中通过- d DEBUG条目为Other Swift Flags键设置DEBUG符号。请看下面的截图举例:

熊子韬的答案和我用的很接近;我还包括文件名(通过剥离file的路径)。

#ifdef DEBUG
    #define NSLogDebug(format, ...) \
    NSLog(@"<%s:%d> %s, " format, \
    strrchr("/" __FILE__, '/') + 1, __LINE__, __PRETTY_FUNCTION__, ## __VA_ARGS__)
#else
    #define NSLogDebug(format, ...)
#endif

在xcode 7中,在Apple LLVM 7.0下有一个字段-预处理,称为“Preprocessors Macros Not Used In Precompiled…” 我把DEBUG放在DEBUG前面,它为我使用下面的代码:

#ifdef DEBUG
    NSString* const kURL = @"http://debug.com";
#else
    NSString* const kURL = @"http://release.com";
#endif

苹果已经在调试版本中包含了DEBUG标志,所以你不需要定义你自己的。

你可能还想考虑在非DEBUG模式下将NSLog重新定义为null操作,这样你的代码将更可移植,你可以只使用常规NSLog语句:

//put this in prefix.pch

#ifndef DEBUG
#undef NSLog
#define NSLog(args, ...)
#endif

在“Apple LLVM -预处理”下检查项目的构建设置,“预处理宏”用于调试,以确保正在设置调试-通过选择项目并单击构建设置选项卡来完成此操作。搜索DEBUG并查看是否确实设置了DEBUG。

不过要注意。您可能会看到DEBUG被更改为另一个变量名,例如DEBUG_MODE。

然后在源文件中有条件地为DEBUG编码

#ifdef DEBUG

// Something to log your sensitive data here

#else

// 

#endif