名字有点绕口,其实更应该翻译为指针函数数组.

记录下对Head-First C这一节的理解,几乎每天班车上都会咪两眼,几乎每次都是看不懂,敲一敲的时候才有些明白.

通俗点讲,这功能解决的是,具有同种签名的方法的数组式调用. 还是不够通俗,书上讲的很通俗:分手信生成器.

对号入座,这是士兵结构体,包含名字以及回信内容类型

enum response_type {DUMP,SECOND_CHANCE,MARRIAGE,LAW_SUIT};
typedef struct
{
char *name;
enum response_type type;
}response;

回信内容所调用的方法:

void dump(response r)
{
printf("Dear %s,\n",r.name);
puts("我們分手吧");
} void second_chance(response r)
{
printf("Dear %s,\n",r.name);
puts("再給你一次機會");
} void marriage(response r)
{
printf("Dear %s,\n",r.name);
puts("我們結婚吧");
}
//
//函数指针数组
//
//
//定義說明:
//
//void 必须是void类型
//(*replies[]) 数组声明,注意是指针数组,需要用*
//(response) 函数接收的参数类型,若有多个,应该是:类型,类型。。。
//{dump,second_chance,marriage} 函数列表,dump,second_chance,marriage是函数名,注意不是枚舉值,枚舉值是大寫的
//
//
//调用方法:
//(replies[r[i].type])(r[i])
//
//其實就是:
//函數名(參數列表)
//
//
//函數名:
//(replies[r[i].type])
//
//r是struct类型,type是枚举类型,枚举类型从0开始
//所以上面的这句如果直接写死的话可以写为:
//(replies[0]),
//也就是说r[i].type取得了一个索引,这个索引决定了要调用的方法的索引:
//{dump,second_chance,marriage}
//{0,1,2}
//r[0].type=dump,也就是调用dump方法,
//然后为dump方法准备传入参数:r[i]
//
//参数列表:
//例如:dump(response r)接收struct response的类型,所以为其准备的参数r[i]就是这种类型 void (*replies[])(response)={dump,second_chance,marriage,law_suit};
int main()
{
response r[]=
{
{"Mike",DUMP},
{"Geroge",MARRIAGE},
{"Vincent",DUMP},
{"Galleleo",SECOND_CHANCE},
{"Furler",MARRIAGE},
{"T-BAG",LAW_SUIT}
}; int i,len=0;
GET_ARRAY_LEN(r,len); for(i=0;i<len;i++)
{
/*
//这是常见的使用switch的方法,如果要加一种类型,可能修改的地方比较多
switch(r[i].type)
{
case DUMP:
dump(r[i]);
break;
case SECOND_CHANCE:
second_chance(r[i]);
break;
case MARRIAGE:
marriage(r[i]);
break;
}
*/ (replies[r[i].type])(r[i]);
} return 0;
}

C 函数指针数组的更多相关文章

  1. C++基础——函数指针 函数指针数组

    ==================================声明================================== 本文版权归作者所有. 本文原创,转载必须在正文中显要地注明 ...

  2. typedef 函数指针 数组 std::function

    1.整型指针 typedef int* PINT;或typedef int *PINT; 2.结构体 typedef struct { double data;}DATA,  *PDATA;  //D ...

  3. C#委托与C语言函数指针及函数指针数组

    C#委托与C语言函数指针及函数指针数组 在使用C#时总会为委托而感到疑惑,但现在总新温习了一遍C语言后,才真正理解的委托. 其实委托就类似于C/C++里的函数指针,在函数传参时传递的是函数指针,在调用 ...

  4. C/C++ 一段代码区分数组指针|指针数组|函数指针|函数指针数组

    #include<stdio.h> #include<stdlib.h> #include<windows.h> /* 举列子说明什么是函数指针 */ //以一个加 ...

  5. C/C++ 不带参数的回调函数 与 带参数的回调函数 函数指针数组 例子

    先来不带参数的回调函数例子 #include <iostream> #include <windows.h> void printFunc() { std::cout<& ...

  6. C语言的函数指针数组(好绕啊~看完这篇估计就通关了)

    转自https://www.cnblogs.com/chr-wonder/p/5168858.html int *(*p(int))[3] 今天有人问这个是啥?我一看直接就懵逼了…… 下面做一些简单的 ...

  7. C++ code:函数指针数组

    函数指针作为一种数据类型,当然可以作为数组的元素类型.例如,要实现用菜单来驱动函数调用的程序框架,则用函数指针数组来实现就比较容易维护. #include<iostream> using ...

  8. c语言.函数指针数组

    函数指针: 一个指向函数的指针.一般用函数名表示. 函数指针数组:元素为函数指针的数组.转移表.c语言中函数不可以定义为数组,只能通过定义函数指针来操作. #include<stdio.h> ...

  9. 转:函数指针数组的妙用(I)

    转自:http://blog.sina.com.cn/s/blog_4c78b35f010008hi.html 笔者在开发某软件过程中遇到这样一个问题,前级模块传给我二进制数据,输入参数为 char* ...

随机推荐

  1. ECMall关于数据查询缓存的问题

    刚接触Ecmall的二次开发不久,接到一个任务.很常见的任务,主要是对数据库进行一些操作,其中查询的方法我写成这样: 01 function get_order_data($goods_id) 02 ...

  2. [topcoder]BestRoads

    http://community.topcoder.com/stat?c=problem_statement&pm=10172&rd=13515 http://community.to ...

  3. android利用剪切板来实现数据的传递

    在Android开发中我们经常要遇到的一个问题就是数据在不同的Activity之间的共享.在Android开发中有很多种方法可以达到这个目地. 这里介绍一种比较常见.又常用的一种方法就是使用剪切板.我 ...

  4. C#利用NPOI生成具有精确列宽行高的Excel文件

    前言 NPOI是操作Excel的神器,导出导入快如闪电, 但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更 ...

  5. BZOJ1345: [Baltic2007]序列问题Sequence

    1345: [Baltic2007]序列问题Sequence Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 556  Solved: 274[Submi ...

  6. 1057 - Collecting Gold (状态压缩DP)

    题目大意: 给你一个矩阵,'x'是你的起始位置, 'g'是宝藏的位置,问最少多少步可以把所有的宝藏取完,并且最后返回起始位置. 注意:没有宝藏的时候输出 0   =================== ...

  7. NHibernate加载DLL错误

    这几天在开发关于Rest的服务,其中用到了NHibernate来进行数据库交互,突然有一天发现了一个错误,如下: Could not load file or assembly 'NHibernate ...

  8. php--常用的时间处理函数

    天地四方曰宇,往古来今曰宙 时间是世界的重要组成部分,不论花开花落,还是云卷云舒都有它的影子. 但它源起何处?又将去向何方?没人知道答案,也不需要答案,我们需要的只是一个相对的起点来标识时间,现今世界 ...

  9. Install MongoDB on Windows

    Overview Use this tutorial to install MongoDB on a Windows systems. PLATFORM SUPPORT Starting in ver ...

  10. hdoj 2063 过山车【匈牙利算法+邻接矩阵or邻接表】

    过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...