我是靠谱客的博主 舒服皮卡丘,最近开发中收集的这篇文章主要介绍(转)“#if 0/1 ... #endif”的作用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本文转载自 https://www.cnblogs.com/kevinGaoblog/archive/2012/04/20/2459814.html

此处转载仅作学习记录,如有侵权,请联系删除。

 

“#if 0/#if 1 ... #endif”的作用,我们知道,C标准不提供C++里的“//”这样的单行风格注释而只提供“/* */”这样的块注释功能,我们通常使用它写代码中说明性的注释文字(注释作用)以及在调试时关闭某段代码对编译器的可见性(屏蔽作用),当然,这里所谓的“注释作用”和“屏蔽作用”是我们从功能上下的主观定义,对预处理器而言,两者并无任何区别。

对于前者,因为“注释”中不会再出现“注释”和“需要屏蔽的代码段”,所以不会有嵌套的需求,所以通常不会有问题;

而对于后者,当我们在调试程序时需要“屏蔽”某段代码时,该段代码中可能包含着前述的“注释”和/或“已被屏蔽的代码段”,这时就产生了“/* */”嵌套使用的需求,但C标准恰恰不允许我们这么干。

当你试图使用嵌套的块注释功能时,会发现预处理器把最外层注释的开始最内层注释的结尾这两者之间的内容处理成了注释,而其后一直到最外层注释结尾的内容被当作了“有效代码”——这显然会引起若干语法错误而导致编译中止。

 

高手们开动脑筋想到了“#if 0 ... #endif”,它同样由预处理器进行处理,同样可以“屏蔽”一段代码,你想把说明文字写在里面也可以,

这些和“/* */”都一样,但不一样的是:

第一它允许嵌套(层数上限由预处理器决定)、

第二你随时可以把“#if 0”改成“#if 1”来取消对某段代码的“屏蔽”

——很卓越的特性,快抛弃笨拙的“/* */”吧!

它唯一的缺点就是在编辑器中没有“注释”该有的文本显示样式。

最后

以上就是舒服皮卡丘为你收集整理的(转)“#if 0/1 ... #endif”的作用的全部内容,希望文章能够帮你解决(转)“#if 0/1 ... #endif”的作用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部