[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 条评论
登录 后参与评论

相关文章

来自专栏SAP最佳业务实践

SAP S/4HANA最佳业务实践:Order-to-Cash订单到收款-5订单处理

•The tile Manage Sales Orders is part of the business catalog Sales –Sales Order...

34912
来自专栏沃趣科技

Oracle Data Guard Feature 12cR2系列(一)

Data Guard是Oracle推出的一种高可用性数据库方案,从Oracle 9i开始正式更名为Oracle Data Guard。Data Guard在11...

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

awr中DB CPU过低的原因分析(r4笔记第20天)

前几天在做巡检的时候发现有个库的负载在某一个时间段内极高,高达100倍。一个10分钟的awr报告,得到的db time 却有1000分钟。 Snap Id ...

2959
来自专栏用户2442861的专栏

数据库经典问题

原文  http://blog.csdn.net/fangjian1204/article/details/39085941

933
来自专栏匠心独运的博客

数据库技术之记一次排查DB死锁的分析与思考

虽然很多童鞋在学数据库课程时都了解数据库隔离级别、死锁和事务等概念,但在测试/线上环境遇到死锁却不一定能够及时分析并解决这类问题。本文主要以作者在测试环境中遇到...

571
来自专栏张善友的专栏

性能计数器数据收集服务

本文演示了一个Windows服务收集性能计数器的数据,将性能计数器数据写入数据库。Windows服务中调用WebAPI服务中。下面简要介绍下我的改造,项目虽小,...

1968
来自专栏用户2442861的专栏

MySQL详解--锁

锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(如CPU、RAM、I/O等)的争用以外,数据也是一种供许多用户共享的资源。如...

533
来自专栏闵开慧

hadoop错误代码查询

经常遇到的exception是:PipeMapRed.waitOutputThreads(): subprocess failed with code N "O...

3766
来自专栏Java帮帮-微信公众号-技术文章全总结

JDBC基础入门(3)

事务 事务是由一步/几步数据库操作序列组成的逻辑执行单元, 这些操作要么全部执行, 要么全部不执行. 注: MySQL事务功能需要有InnoDB存储引擎的支持,...

3407
来自专栏IT杂记

JDBC批量提交SQL的几点问题解答

1. 疑问 问题一:Statement的executeBatch方法是否会执行commit操作,是否还需要再执行一次commit()? 问题二:执行批量操作的过...

2217

扫码关注云+社区