[C/C++]函数指针和函数分发表

// console.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <iostream>
using namespace std;

typedef unsigned char UCHAR;
int FunA();
int FunB();
int FunC();

typedef enum tagMsgType
{
    MSG_TYPE_A = 1,
    MSG_TYPE_B,
    MSG_TYPE_C
};

typedef int (*MSG_PROC_FUNC)();

typedef struct tagMsgDispatchTbl
{
    UCHAR ucMsgType;
    MSG_PROC_FUNC pFuc;
} MsgDispatchTbl;

MsgDispatchTbl g_astDispatchTbl[] = 
{
    {MSG_TYPE_A, FunA},
    {MSG_TYPE_B, FunB},
    {MSG_TYPE_C, FunC},
};

int FunA()
{
    printf("Call FunA\r\n");
    return 0;
}

int FunB()
{
    printf("Call FunB\r\n");
    return 0;
}

int FunC()
{
    printf("Call FunC\r\n");
    return 0;
}

int _tmain(int argc, _TCHAR* argv[])
{
    int i = 1;
    int iRet = 0;
    UCHAR ucMsgType = MSG_TYPE_B;
    UCHAR aucStr[1024] = {0};
    MSG_PROC_FUNC pFunc;
    for (i = 1; i < 4; i++)
    {
        if (ucMsgType == g_astDispatchTbl[i].ucMsgType)
        {
            pFunc = g_astDispatchTbl[i].pFuc;
            pFunc();
        }
        
    }
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏xingoo, 一个梦想做发明家的程序员

windows程序设计-第四章 system2.c 新增滚动条功能

新添加的滚动条功能,首先就是要在createWindow的时候,修改参数风格模式 hwnd = CreateWindow (szAppName, TE...

1989
来自专栏我的博客

Ubuntu初始化svn一系列脚本

个人ubuntu服务器初始化svn脚本,虽然很烂,但是自己用起来很方便!(为何写ubuntu呢?因为centos的svn模块和ubuntu不一样!) #!/bi...

3464
来自专栏乐沙弥的世界

Linux/Unix shell 监控Oracle监听器(monitor listener)

    使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,A...

1324
来自专栏杨建荣的学习笔记

Oracle 12c中JOB运行失败的简单处理(r11笔记第66天)

在之前简单分析过一个12c中数据字典的小问题。 Oracle 12c数据字典的小问题(r11笔记第49天) 最近查看邮件,12c的一个PDB还是存在JOB运行异...

2987
来自专栏我的博客

Subversion 301 Moved Permanently 的解決方法

1.要保证svn和document不同一目录 官方说明:http://subversion.tigris.org/project_faq.html#301-er...

2063
来自专栏tiane12

DB2备份恢复流程

1041
来自专栏互联网技术栈

APM开源产品Pinpoint——Hbase表设计文档

1473
来自专栏Jerry的SAP技术分享

如何利用BAPI SD_SALESDOCUMENT_CHANGE修改一个Sales Order的字段

假设我想修改S/4HANA里Sales Order抬头的Service Date字段SERV_DATE:

613
来自专栏杨建荣的学习笔记

session跟踪失效的问题和分析(57天)

最近碰到一个奇怪的问题,在生产和其他比较正式的环境中进行sql trace都没问题,但就是测试环境的数据库不知道怎么的, 设置sql_trace,开启诊断事件,...

35810
来自专栏乐沙弥的世界

PL/SQL 包编译时hang住的处理

       最近PL/SQL包在编译时被hang住,起初以为是所依赖的对象被锁住。结果出乎意料之外。下面直接看代码演示。

856

扫码关注云+社区