如同绝大多数的语言入门书籍一般,第1章主要是起到一个引入的作用,对语言做出大体上的介绍并且给出几个基本程序来让读者感受。不过不同的是,《C++ Primer》的第1章感觉还是比其他的书硬核了许多,上来就给出一段代码和一大堆术语恐怕对新手不大友好。
尝试细致地读过第1章,并没获得多大的收获,有两个小点在这里记录一下吧。
关于嵌套注释的实际情况
书中在讲解注释的时候,提到了使用注释界定符时可能遇到的注释嵌套问题,这个我是知道的,但看到习题给出的几种嵌套注释的案例,突然很好奇编译器会怎么理解嵌套的注释。
并且,在遇上同样“鲸吞一切”的引号时,编译器会偏向注释界定符还是引号呢。
这里给出书上联系1.8的第4个例子,我分别在VS和CodeBlocks上测试了,都和这里CSDN的高亮方式是一样的。
std::cout << /* "*/" /* "/*" */;
可以看得出来,第一对引号中是注释结束符,在引号之前已经有注释起始符表示注释的开始,在引号里遇到结束符以后就结束了注释。而对于第二个起始符,是被两个引号包裹的,这里被识别为了字符串的一部分而没有开始注释。
仔细一思考,或许注释起始符和引号的地位和处理方式是比较接近的,编译器遇到注释起始符就认为开始注释,后面遇到的任何非注释结束符的字符(包括引号)都认为是注释的一部分;编译器遇到第一个引号就认为开始字符串,后面遇到的任何非右引号的字符(包括注释界定符)都认为是字符串的一部分。
所以应该两者地位对等,且都是遵循先到先得的原则。
关于重定向输入
平常使用的最多的是借助freopen的代码内重定向,书上介绍了从调用端进行重定向的方式,代码如下
program <infile >outfile
其中program是可执行文件的文件名,infile是输入文件的文件名,小于号表示输入程序;outfile是输出文件的文件名,大于号表示输出到文件。