c陷阱与缺陷 心得体会 1

来源:互联网 发布:linux系统启动自检 编辑:程序博客网 时间:2024/04/27 02:53

      今天比较懒惰,没做题,只是看了一点那本c陷阱与缺陷,说实话读了不多但明显能感觉出这是一本好书,感觉对我来说刚好,不是基础书,但也基本能看懂,而且能学到好多东西,但今天只看了三章,主要是下军旗了,囧,我也只能把我学到的总结下来,学了总比一点都没学要好,我也只能这样安慰自己了。

     首先就是一个很基本的问题,但我以前不知道的,就是c语言编译器如何进行词法分析,就比如说下面这个表达式a---b,当编译器拿到这个表达式时,它会怎么分析呢?现在我知道了,c语言的编译器遵循“贪心法”,所谓的贪心法就是编译器从左到右一个一个字符读入,如果该字符能组成一个符号,那就再读入下一个字符,判断已经读入的字符串是否可能是一个符号的组成部分,如果是那就再读入一个字符,接着判断这3个字符组成的字符串是否可能是一个符号的组成部分,如果是,那就接着读,直到所读入的字符串不可能组成一个符号,所以对于上述的表达式,正确的理解是(a--)-b,还有相关的一点是符号间可以有空格,但一个符号内有空格和没空格是有区别的,还是拿上述表达式说,(1)a-- -b(2)a- --b,这两个是不同的,第一个和原始的是同一个意思。还有一个典型的例子就是y=x/*p,本意p是一个指向整数的指针,想把x除以p所指向的数赋给y,但事实上/*会被编译器解释为注释的一部分。

     第二就是书里对C语言单引号和双引号区别的阐述,C语言用单引号引起的一个字符实际上代表一个整数,整数值对应于该字符在编译器采用的字符集中的序列值。一般编译器采用的是ASCII字符集。用双引号引起的字符串代表的是指向一个无名数组起始字符的指针,该数组被双引号之间的字符和一个额外的二进制值为零的字符'/0'初始化。

     第三点就是来看一下这个表达式(*(void(*)( ) )0)( ),第一眼看确实比较晕,但经过他的解释后我懂了,首先是(void(*)( )),这总体是个强制类型转化,括号里面的是个函数指针,也就是说把0这个地址转化为一个函数指针,然后执行这个地址上的函数。这里还有个函数声明,看的不太懂,留作以后的一个问题吧void(*signal( int ,void(*)( int ) ))( int );

     最后一个就是switch无break的妙用,有下面一个例子,就是编译器在查找符号时要跳过程序中的空格,制表和换行符,编译器对三者的处理是相同的,除了遇到换行符时程序的代码计数器要递增

case '/n':

            linecount++;

           /*这里没有break*/

case '/t':

case ' ':

          ...处理语句


   

原创粉丝点击