类型的右左法则

右左法则: 

0. 规则中符号 

 *  读作 “指向...的指针”   
 []   读作 “...的数组”   
 ()  读作 “返回...的函数” 


1. 起始点 

 找到声明中的标识符(Identifier),它就是你分析的起始点,读作:“$(Identifier)是...”; 


2. 右边 


 看你的标识符右边 
 a) 如果发现“()”,你将知道这是一个函数声明,这时你可以说“$(Identifier)是返回...的函数”; 
 b) 如果发现“[]”,你将知道这是一个数组声明,这时你可以说“$(Identifier)是...的数组”; 
 c) 继续向右,直到遇到右边声明结束或者遇到“)”,继续下面。 


3. 左边 


 看你的标识符左边 
 a) 如果碰到的不是我们在0.中定义的符号,则直接说出它;否则按照0.中定义的符号含义说出。继续向左,直到遇到左边声明结束或“(”。 
4. 重复2和3的步骤,直到声明分析完毕。 


例子详解 


我们从简单到复杂,循序渐进。 


[Example 1] int *p[]; 
1) 找到标识符:p,读作:“p是...”; 
2) 向右看:发现一“[]”,然后遇到右边声明结尾,读作:“p是...的数组”; 
3) 向左看:发现一“*”, 读作:“p是指向...的指针的数组”; 
4) 继续向左看:没有发现0.中定义的符号,则分析结束,读作:“p是指向int类型的指针的数组”。 

 


[Example 2] int *(*func())(); 
1) 找到标识符:func,读作:“func是...”; 
2) 向右看:发现一“()”,然后遇到“)”,读作:“func是返回...的函数”; 
3) 向左看:发现一“*”,然后遇到“(”,读作:“func是返回指向...的指针的函数”; 
4) 向右看:发现一“()”,然后右边声明结束,读作:“func是返回指向返回...的函数的指针的函数”; 
5) 向左看:发现一“*”,读作:“func是返回指向返回指向...的指针的函数的指针的函数”; 
6) 向左看:没有发现.中定义的符号,则分析结束,读作:“func是返回指向返回指向int类型的指针的函数的指针的函数”。 

posted @ 2020-03-16 11:19  sufei  阅读(166)  评论(0编辑  收藏  举报