今天比较懒惰,没做题,只是看了一点那本c陷阱与缺陷,说实话读了不多但明显能感觉出这是一本好书,感觉对我来说刚好,不是基础书,但也基本能看懂,而且能学到好多东西,但今天只看了三章,主要是下军旗了,囧,我也只能把我学到的总结下来,学了总比一点都没学要好,我也只能这样安慰自己了。
首先就是一个很基本的问题,但我以前不知道的,就是c语言编译器如何进行词法分析,就比如说下面这个表达式a---b,当编译器拿到这个表达式时,它会怎么分析呢?现在我知道了,c语言的编译器遵循“贪心法”,所谓的贪心法就是编译器从左到右一个一个字符读入,如果该字符能组成一个符号,那就再读入下一个字符,判断已经读入的字符串是否可能是一个符号的组成部分,如果是那就再读入一个字符,接着判断这3个字符组成的字符串是否可能是一个符号的组成部分,如果是,那就接着读,直到所读入的字符串不可能组成一个符号,所以对于上述的表达式,正确的理解是(a--)-b,还有相关的一点是符号间可以有空格,但一个符号内有空格和没空格是有区别的,还是拿上述表达式说,(1)a-- -b(2)a- --b,这两个是不同的,第一个和原始的是同一个意思。还有一个典型的例子就是y=x/*p,本意p是一个指向整数的指针,想把x除以p所指向的数赋给y,但事实上/*会被编译器解释为注释的一部分。