一、通过指针传递函数与通过指针传递数据的本质是一样的,区别就是此时的数据是函数指针(函数的开始的地址)

    1、定义:通过函数指针将函数传入函数;通过函数返回函数指针实现函数返回函数的目标

    2、特征:

      1)、通过函数指针的介入,使函数调用变得更加灵活,实现功能的封装性

      2)、使真正的函数下沉一层,有利于函数功能的抽象

      3)、是函数的交互变得更加自然与方便

    3、函数指针:

      1)、定义:与普通函数的定义基本类似,包括函数类型、函数名称和函数参数;形如 int  (*guoCal)(int, int);

      2)、特征:唯一的区别就是在函数名称前加上*,并使用()将*和函数名称包括起来;

      3)、说明:上述定义的是返回类型为int ,函数参数为两个int类型的函数的指针;

      4)、应用:若存在上述定义,存在函数int add(int, int), int sub(int, int), 则可以有guoCal = add; guoCal = sub等语句

  代码如下:

        1)、通过函数指针使函数返回函数:

  #include <stdio.h>

  int add(int var1, int var2){
return var1 + var2;
} int sub(int var1, int var2){
return var1 - var2;
} int mul(int var1, int var2){
return var1 * var2;
} int div(int var1, int var2){
return var1 / var2;
} int mod(int var1, int var2){
return var1 % var2;
} void inputVar(int *var1, int *var2){
printf("Please input var1: ");
scanf("%d", var1); printf("Please input var2: ");
scanf("%d", var2); return;
} typedef int (*ptrCal)(int, int); ptrCal resultCal(char *ch){
ptrCal cal1;
printf("Please input ch: ");
scanf("%c", ch); switch(*ch){
case '+':
cal1 = add;
break; case '-':
cal1 = sub;
break; case '*':
cal1 = mul;
break; case '/':
cal1 = div;
break; case '%':
cal1 = mod;
break; default:
printf("you can select:+ - * / %!\n");
} return cal1;
} int main(int argc, char **argv)
{
ptrCal cal2;
int var1;
int var2;
char ch;
inputVar(&var1, &var2);
getchar();
cal2 = resultCal(&ch);
printf("The %d %c %d = %d\n", var1, ch, var2, cal2(var1, var2)); return ;
}

      2)、通过将函数指针作为函数的参数:

  #include <stdio.h>

  int add(int var1, int var2){
return var1 + var2;
} int sub(int var1, int var2){
return var1 - var2;
} int mul(int var1, int var2){
return var1 * var2;
} int div(int var1, int var2){
return var1 / var2;
} int mod(int var1, int var2){
return var1 % var2;
} void inputVar(int *var1, int *var2){
printf("Please input var1: ");
scanf("%d", var1); printf("Please input var2: ");
scanf("%d", var2); return;
} typedef int (*ptrCal)(int, int); int resultCal(ptrCal cal, int var1, int var2){
return cal(var1, var2);
} int main(int argc, char **argv)
{
int var1;
int var2;
inputVar(&var1, &var2);
printf("The %d + %d = %d\n", var1, var2, resultCal(add, var1, var2));
printf("The %d - %d = %d\n", var1, var2, resultCal(sub, var1, var2));
printf("The %d * %d = %d\n", var1, var2, resultCal(mul, var1, var2));
printf("The %d / %d = %d\n", var1, var2, resultCal(div, var1, var2));
printf("The %d %% %d = %d\n", var1, var2, resultCal(mod, var1, var2)); return ;
}

    可以看到,借助函数指针令函数调用更加灵活。

22深入理解C指针之---通过指针传递函数的更多相关文章

  1. 浅谈 .NET 中的对象引用、非托管指针和托管指针 理解C#中的闭包

    浅谈 .NET 中的对象引用.非托管指针和托管指针   目录 前言 一.对象引用 二.值传递和引用传递 三.初识托管指针和非托管指针 四.非托管指针 1.非托管指针不能指向对象引用 2.类成员指针 五 ...

  2. 从IL角度彻底理解回调_委托_指针

    从IL角度彻底理解回调_委托_指针 目录 从IL角度彻底理解回调_委托_指针 1.创作此文的背景 1.1.委托能帮助代码更好地封装 1.2.委托能随时随地更方便地运行其他类中的方法 1.3.委托非常适 ...

  3. 关于C语言的指针数组与指针数组的个人理解

    一.指针数组与指针数组 1,指针数组 顾名思义,即一个元素全部是指针的数组,其形式与普通数组相似,形式如 *a[N]. 在理解指针数组的使用方式前,我先来说下我个人对数组的理解. 比如一维整形数组(形 ...

  4. 深入理解C语言中的指针与数组之指针篇

    转载于http://blog.csdn.net/hinyunsin/article/details/6662851     前言 其实很早就想要写一篇关于指针和数组的文章,毕竟可以认为这是C语言的根本 ...

  5. 深入理解C语言中的指针与数组之指针篇(转载)

    前言 其实很早就想要写一篇关于指针和数组的文章,毕竟可以认为这是C语言的根本所在.相信,任意一家公司如果想要考察一个人对C语言的理解,指针和数组绝对是必考的一部分. 但是之前一方面之前一直在忙各种事情 ...

  6. 深入理解C指针之五:指针和字符串

    原文:深入理解C指针之五:指针和字符串 基础概念 字符串可以分配到内存的不同区域,通常使用指针来支持字符串操作.字符串是以ASCII字符NUL结尾的字符序列.ASCII字符NUL表示为\0.字符串通常 ...

  7. 深入理解C指针之六:指针和结构体

    原文:深入理解C指针之六:指针和结构体 C的结构体可以用来表示数据结构的元素,比如链表的节点,指针是把这些元素连接到一起的纽带. 结构体增强了数组等集合的实用性,每个结构体可以包含多个字段.如果不用结 ...

  8. 深入理解C指针之四:指针和数组

    原文:深入理解C指针之四:指针和数组 数组是C内建的基本数据结构,数组表示法和指针表示法紧密关联.一种常见的错误认识是数组和指针完全可以互换,尽管数组名字有时可以当做指针来用,但数组的名字不是指针.数 ...

  9. 深入理解C指针之三:指针和函数

    原文:深入理解C指针之三:指针和函数 理解函数和指针的结合使用,需要理解程序栈.大部分现代的块结构语言,比如C,都用到了程序栈来支持函数的运行.调用函数时,会创建函数的栈帧并将其推到程序栈上.函数返回 ...

  10. typedef void (*Fun) (void) 的理解——函数指针——typedef函数指针

    首先介绍大家比较熟悉的typedef int i;//定义一个整型变量i typedef myInt int: myInt j;//定义一个整型变量j 上面介绍得是我们常用的比较简单的typedef的 ...

随机推荐

  1. 类扩展Extension

    延展(Extension):在本类里声明私有方法. 1:延展定义的方法是在implemetation中. 2:声明的方法是私有方法. 3:延展中声明的方法可以不实现. #import "Ho ...

  2. JS与 JSON(一个菜鸟的不正经日常)

    今天学习了json的一些知识, 1 . 什么是json 1.1  JSON 英文全称 JavaScript Object Notation. 1.2  JSON 是一种轻量级的数据交换格式,用于存储和 ...

  3. 【贪心】10.24assassin

    题目分析 没有题目分析…… 寄存一下神奇反悔贪心 #include<bits/stdc++.h> ; struct node { int a,b; node(, ):a(x),b(y) { ...

  4. docker镜像下载

    获得CentOS的Docker CE 预计阅读时间: 10分钟 要在CentOS上开始使用Docker CE,请确保 满足先决条件,然后 安装Docker. 先决条件 Docker EE客户 要安装D ...

  5. centos7 rpm安装mysql5.7

    1.去官网下载指定的数据库版本:https://dev.mysql.com/downloads/mysql/ 2.根据所用的操作系统下载指定的rpm包 3.下载及安装 地址链接wget https:/ ...

  6. PHP 日常开发过程中的bug集合(持续更新中。。。)

    PHP 日常开发过程中的bug集合(持续更新中...) 在日常php开发过程中,会遇到一些意想不到的bug,所以想着把这些bug记录下来,以免再犯! 1.字符串 '0.00'.'0.0'.'0'  是 ...

  7. 第十四届华中科技大学程序设计竞赛决赛同步赛 Beautiful Land

    It’s universally acknowledged that there’re innumerable trees in the campus of HUST.Now HUST got a b ...

  8. 2015多校训练第二场 hdu5305

    把这题想复杂了,一直在考虑怎么快速的判断将选的边和已选的边无冲突,后来经人提醒发现这根本没必要,反正数据也不大开两个数组爆搜就OK了,搜索之前要先排除两种没必要搜的情况,这很容易想到,爆搜的时候注意几 ...

  9. BZOJ 5441: [Ceoi2018]Cloud computing

    背包 #include<cstdio> #include<algorithm> using namespace std; int n,m,Len; long long F[2] ...

  10. UVa 1354 枚举子集 Mobile Computing

    只要枚举左右两个子天平砝码的集合,我们就能算出左右两个悬挂点到根悬挂点的距离. 但是题中要求找尽量宽的天平但是不能超过房间的宽度,想不到要怎样记录结果. 参考别人代码,用了一个结构体的vector,保 ...