深入解析函数指针与返回函数的指针_C 语言

先看看以下两个代码:
1:出自STL-SGI源码<stl_alloc.h>

复制代码 代码如下:

static void (*__set_malloc_handler(void (*__f)()))()
{
 void (*__old)()=__malloc_alloc_oom_handler;
 __malloc_alloc_oom_handler=__f;
 return (__old);
}

2:Linux下的<sginal.h>

复制代码 代码如下:

void (*signal (int sig_num, void (*handler)(int))) (int) 

作为一个C/C++高手也许一看就明白,下面来分析一下,分析的方法采用的是从里向外的分析法

对于例子1分析如下:
1)最里面是void (*_f)()说明_f是一个指针,与右边的()结合,说明其是一个函数,在与最左边的void结合,表明其是一个函数指针。

2)用typedef对void (*_f)()进行一下定义,方便后面的分析

Typedef void (*F)()

3)于是上面的代码可以变成如下的形式
Static void (*__set_malloc_handler(F f))()

4)再从里向外分析__set_malloc_handler(F f)先与()结合表明其是一个函数,参数类型为F f,再于左边的*结合,表明函数返回的是一个指针类型,即static void (*)(),因此是一个函数指针

5)综上可以得到代码函数名为__set_malloc_handler,接受一个返回值为空,参数为空的函数指针作为参数,最后返回一个函数指针,该指针同样返回值与参数均为空,很绕口:)

对于例子2分析如下
1)从里向外里面是void (* handler)(int)看过列子1,很容易知道这是一个函数指针,返回值为空,参数为空

2)对void (*handler)(int)进行宏定义,以方便理解
Typedef void (*Handle)(int)

3)于是函数就变成了void (*signal(intsig_num,Handler handler))(int)

4)从里向外分析signal(int sig_num,Handlerhandler)是一个函数,带两个参数,返回值是*,即是一个指针,返回值为void(*)(int)同样是一个Handler类型的函数指针

5)综上所述,代码2的函数名是signal,接受两个参数,返回一个Handler类型的函数指针。

其他代码的分析类似,如下几例:

复制代码 代码如下:

1:void *(*(*f)(int))[10];
分析如下(*(*f)(int)->void *(*)[10]
2:void *(*f)(int)[10]
分析如下(*f)(int)->void *[10]

还有一些基本上都是类似的变形

时间: 2024-10-14 13:19:34

深入解析函数指针与返回函数的指针_C 语言的相关文章

深入解析函数指针与返回函数的指针

以下是对函数指针与返回函数的指针进行了详细的分析介绍,需要的朋友可以过来参考下   先看看以下两个代码:1:出自STL-SGI源码<stl_alloc.h> 复制代码 代码如下: static void (*__set_malloc_handler(void (*__f)()))() {  void (*__old)()=__malloc_alloc_oom_handler;  __malloc_alloc_oom_handler=__f;  return (__old); } 2:Linux

C语言 用指针作为函数返回值详解_C 语言

C语言允许函数的返回值是一个指针(地址),我们将这样的函数称为指针函数.下面的例子定义了一个函数 strlong(),用来返回两个字符串中较长的一个: #include <stdio.h> #include <string.h> char *strlong(char *str1, char *str2){ if(strlen(str1) >= strlen(str2)){ return str1; }else{ return str2; } } int main(){ cha

C语言 函数指针(指向函数的指针)详解_C 语言

一个函数总是占用一段连续的内存区域,函数名在表达式中有时也会被转换为该函数所在内存区域的首地址,这和数组名非常类似.我们可以把函数的这个首地址(或称入口地址)赋予一个指针变量,使指针变量指向函数所在的内存区域,然后通过指针变量就可以找到并调用该函数.这种指针就是函数指针. 函数指针的定义形式为: returnType (*pointerName)(param list); returnType 为函数返回值类型,pointerNmae 为指针名称,param list 为函数参数列表.参数列表中

如何通过函数指针调用函数(实现代码)_C 语言

说明:指针可以不但可以指向一个整形,浮点型,字符型,字符串型的变量,也可以指向相应的数组,而且还可以指向一个函数. 一个函数在编译的时候会被分配给一个入口地址.这个函数入口地址称为函数的指针.可以用一个指针变量指向函数,然后通过该指针变量调用此函数. 定义指向函数的指针变量的方法是: 复制代码 代码如下: int (*p) (int ,int ); int[指针变量p指向的函数的类型] (*p)[p是指向函数的指针变量] ( int,int )[p所指向的形参类型]; 与函数的原型进行比较 复制

c语言:基于函数指针的两个示例分析_C 语言

第一个:------------------------------------------------------ 复制代码 代码如下: #include <stdio.h>#include <string.h>void tell_me(int f(const char *, const char *));int main(void){   tell_me(strcmp);   tell_me(main);   return 0;}void tell_me(int f(const

C语言指针的长度和类型深入分析_C 语言

指针是C语言的精髓,本文就以实例的形式详细分析了C语言的长度和类型.对于初学者深入理解C语言程序设计有很好的参考价值.具体分析如下: 一般来说,如果考虑应用程序的兼容性和可移植性,指针的长度就是一个问题,在大部分现代平台上,数据指针的长度通常是一样的,与指针类型无关,尽管C标准没有规定所有类型指针的长度相同,但是通常实际情况就是这样.但是函数指针长度可能与数据指针的长度不同. 指针的长度取决于使用的机器和编译器,例如:在现代windows上,指针是32位或是64位长 测试代码如下: #inclu

C++中指针和引用的区别分析_C 语言

从概念上讲.指针从本质上讲就是存放变量地址的一个变量,在逻辑上是独立的,它可以被改变,包括其所指向的地址的改变和其指向的地址中所存放的数据的改变. 而引用是一个别名,它在逻辑上不是独立的,它的存在具有依附性,所以引用必须在一开始就被初始化,而且其引用的对象在其整个生命周期中是不能被改变的(自始至终只能依附于同一个变量). 在C++中,指针和引用经常用于函数的参数传递,然而,指针传递参数和引用传递参数是有本质上的不同的: 指针传递参数本质上是值传递的方式,它所传递的是一个地址值.值传递过程中,被调

C++基础之this指针与另一种“多态”_C 语言

一.引入定义一个类的对象,首先系统已经给这个对象分配了空间,然后会调用构造函数. 一个类有多个对象,当程序中调用对象的某个函数时,有可能要访问到这个对象的成员变量.而对于同一个类的每一个对象,都是共享同一份类函数.对象有单独的变量,但是没有单独的函数,所以当调用函数时,系统必须让函数知道这是哪个对象的操作,从而确定成员变量是哪个对象的.这种用于对成员变量归属对像进行区分的东西,就叫做this指针.事实上它就是对象的地址,这一点从反汇编出来的代码可以看到. 二.分析1.测试代码: 复制代码 代码如

C语言指针学习经验总结浅谈_C 语言

   这篇C语言指针学习经验总结主要是我入职以来学习C指针过程中的点滴记录.文档里面就不重复书上说得很清楚的概念性东西,只把一些说得不清楚或理解起来比较费解的东西做一下讲解,希望能达到以下三个目的 1.通过写这些东西,把我脑袋中关于C的模糊的知识清晰化.2.给初转C的同事们一点提示和帮助.3.也希望各位前辈检查一下文档中是否有理解偏差的地方.1 指针的概念分解      指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址. 要搞清一个指针需要搞清指针的四方面的内容: 1.指针的类型