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 @   飞林沙  阅读(465)  评论(6编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
历史上的今天:
2009-04-18 一步一步学WF系列(六)——工作流模拟投票项目
点击右上角即可分享
微信分享提示