在我看到的所有关于#if编译器指令的例子中,它们都使用了“DEBUG”。我可以以同样的方式使用“RELEASE”来排除在调试模式下编译时不想运行的代码吗?我想用这个块包围的代码会发送一堆电子邮件,我不想在测试时意外地发送这些邮件。
当前回答
RELEASE没有定义,但是您可以使用
#if (!DEBUG)
...
#endif
其他回答
我知道这是一个老问题,但值得一提的是,您可以在DEBUG和RELEASE之外创建自己的配置,例如TEST或UAT。
如果在项目属性页的Build选项卡上,你将“条件编译符号”设置为TEST(例如),你就可以使用这样的构造
#if (DEBUG || TEST )
//Code that will not be executed in RELEASE or UAT
#endif
您可以出于特定的原因使用此构造,例如,如果需要,可以使用不同的客户端,甚至可以使用整个Web方法。我们过去也使用过这种方法,因为某些命令在特定的硬件上导致了问题,所以当部署到硬件X时,我们有一个应用程序的配置。
“流行卡特林”说对了。基于构建类型控制定义提供了很大的灵活性。例如,您可以在同一个解决方案中拥有“DEBUG”、“DEMO”和“RELEASE”配置。这避免了使用两个不同的解决方案进行重复编程的需要。
因此,当定义RELEASE条件编译符号时,#if RELEASE或#if (RELEASE)的工作原理与#if DEBUG相同。
以下是来自“Pop Catalin”的帖子: 如果你想为发布配置定义一个RELEASE常量,请到: *项目属性->构建 *选择释放模式 *在条件编译符号文本框中输入:RELEASE
为此,您可以使用#if(!DEBUG)。
虽然M4N的答案(#if (!DEBUG))最有意义,但另一种选择可能是使用预处理器来修改其他标志的值;如。
bool isRelease = true;
#if DEBUG
isRelease = false;
#endif
或者更好的方法是,使用定义预期行为的标志,并根据模式设置它们,而不是引用我们是在发布模式还是调试模式:
bool sendEmails = true;
#if DEBUG
sendEmails = false;
#endif
这与使用预处理器标志是不同的,因为这些标志在生产中仍然存在,所以每次调用该代码时,您都会产生if (sendEmails) {/* send邮件*/}的开销,而不是在发布版中存在但在调试中不存在的代码,但这可能是有利的;例如,在你的测试中,你可能想要调用你的SendEmails()方法,但在模拟上,同时在调试中运行以获得额外的输出。
我以前从来没见过……但我已经看到:
#if (DEBUG == FALSE)
and
#if (!DEBUG)
对你有用吗?
推荐文章
- i++和++i的区别是什么?
- 可空对象必须有一个值
- 按类型查找WPF窗口中的所有控件
- 为什么我不能继承静态类?
- 数组与列表的性能
- 如何在c#中获取CPU的使用情况?
- BindingFlags。IgnoreCase不为Type.GetProperty()工作?
- 使用私有静态方法的优点
- 一个任务被取消了?
- 新DateTime()与默认值(DateTime)
- 如何设置断点在内联Javascript在谷歌Chrome?
- 从Description属性中获取Enum
- 从包含文件名的路径获取不包含文件名的完整路径
- 如何从字符串的开始或结束删除所有空白?
- 为什么使用try {} finally{}和一个空的try块?