亲宝软件园·资讯

展开

c++代码注释

鹿九丸 人气:0

1、前言

今天想带大家来了解一下注释,当然,是C语言中的注释,这个大家都并不会感到陌生,但是,当有一天面试官问你?小伙子啊,你能给我讲讲什么是注释吗?大家应该都会懵的吧,毕竟注释有什么可讲的呢?但是事实真的如此吗?今天就由我来带大家了解一下注释吧!

2、正文(危)

1.以代码例子为例

(1)代码段1

首先来几段注释的例子大家来判断下对错(从语法角度和是否实现注释的效果来看)

#include <stdio.h>
int main()
{
	int /* */ i; 
	char* s = "abcdefgh //hijklmn";
	//Is it a\
	valid comment? 
	in/* */t j; 
	return 0;
}

当大家把这段代码放在vs上去运行的时候,报错的代码只有最后一行代码,即in/* */t j;我们就知道这行代码是有语法错误的,那么其它的代码就完全没有问题了吗?当然,其它的代码没有了语法错误,但是它们的注释效果真正实现了吗?

补充知识:注释被替换是在预处理阶段实现的,注释被替换,本质是替换成空格,上述报错的那一句本质上应该是 in t i;编译器自然会报错,报错是在预处理阶段进行语法检查时出错的,出现了语法错误。

这个是编译器上的标识图,上面的几行代码虽然没有报语法错误,但是有的代码却没有真正实现其注释的效果,下面我们将一行一行的带大家来进行分析!

首先看第一行:int   /* */   i;经过替换后。中间的转换为空格,可见并没有语法错误,且能够达到注释的目的。

接下来看第二行代码,这个地方大家可能会感到疑惑了,我命名加了注释符的啊,但是为什么没有达到我想要的效果呢?这个地方的原因是因为//是在字符串中,此时的第一个/被理解成了转义字符,而第二个则真正被理解成了/,至于为什么第二个/没有被理解成转义字符呢?因为第一个/防止了后面的字母被转义,所以后免的一个/才没有被理解成是转义字符,好像扯的有点远了。这个地方需要告诉大家的是在字符串中是无法进行注释的,因为在字符串中的/有特殊的含义!

有的朋友就好奇了,既然C++风格的注释行不通,那么C语言的风格能否行得通呢?答案是不能,下面给大家证明一下吧!

很明显,依旧没有成功行注释,原因同上。

接下来来看第三行代码,我们可以得出一个结论,C++风格的注释是可以续行的!

(2)代码段2

/*这是*/#/*一条*/define/*合法的*/ID/*预处理*/replacement/*指*/list/*令*/
//这段代码指的就是用replacement list替换ID

当这段代码放到VS上是这样的:

上述两段代码都能编译通过,这说明# 和 define之间可以带空格。(因为注释最终要被空格所代替)

//是C++风格的注释,而/* */则是C语言风格的注释,前者可以一次写多个,不过从第一个//往后就都是注释的内容。

(3)代码段3

/*
/*
*/
*/

 这段代码在vs中是下面这样的:

 注意:/* */不能嵌套注释。/*总是和离它最近的*/进行匹配。

在这段代码中,最终第一行和第三行中的*/进行匹配,剩下最后一个*/没有与之进行配对的。

(4)代码段4

int x = 10 ;
int y = 10;
int z = 5;
int *p = &z;
y = x/*p;

上面这种代码一定要注意,乍一看没有什么问题,但是接下来我们放到编译器上看一下:

这种代码一定要注意,/*容易被编译器认为是注释,所以会报错。

解决方案有两种:

1.y = x / *p;即在/后面加一个空格,不要让/*连在一起。

2.y = x/(*p);(推荐用第二种)。

2.其它的注释方法

(1)条件编译

#include <stdio.h>
#include <windows.h>
#define MONEY 1(只有定义了前面的宏,ifdef到endif中间的这段代码才能够正常运行,未定义则跳过)
int main()
{
#ifdef MONEY
	printf("for test1\n"); //test1
	printf("for test2\n"); //test2
#endif
	system("pause");
	return 0;
}

(2)if条件

可以通过if(0)来进行注释,但并不推荐。

加载全部内容

相关教程
猜你喜欢
用户评论