C语言学习笔记(16)

在C语言中,经常会出现一些复杂的类型声明。而大多数都是涉及到指针的类型。

那么就在这一节来集中认识一下。

首先,我们先来了解*,()和[]的组合。在看实际例子前,先来看一个重要的规则:

在做选择时,始终使[]和()的优先级大于*。举个简单的例子:

int *arr[10]。由于[]的优先级大于*。也就代表,首先这是一个含有10个元素数组,那么数组内的内容是什么呢?是int *arr。去掉类型名称,数组内的类型是int *。所以这是一个含有10个整数类型指针的数组。

同样的规则继续看:float *fp(float)。由于()的优先级大于*,所以说明这首先是一个函数,函数的返回类型是指向float类型的指针。

void (*fp)(float)。由于括号的存在,代表首先这是一个指针,这个指针指向什么呢?指向的是一个参数个数为1,类型是float的函数。

接下来看一个复杂的:(*(void(*)())0)();让我们慢慢来拆分,首先(void(*))()是一个函数指针类型的原型,因此(void(*)())0是将0转换成一个函数指针类型,那么(*(void(*)())0)也就是地址0处所在的函数,那么上面一条语句的意思也就是执行地址0处的函数。

上面的语句看起来非常复杂繁琐,因此我们在实际工作中,最好使用typedef来重新制定一下比较复杂的数据类型:

例如上面的例子:我们不妨typedef void (*functionPoint)(); 这样我们就可以非常简单的

(*(functionPoint)0)();

这样是不是容易理解了很多呢?

 

posted @ 2010-04-18 14:44  飞林沙  阅读(463)  评论(6编辑  收藏  举报