news 2026/6/15 14:14:53

switch-case 语句分析(消灭swich-case方法)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
switch-case 语句分析(消灭swich-case方法)

author: hjjdebug
date: 2026年 01月 23日 星期五 10:46:02 CST
descrip: switch-case 语句分析(消灭swich-case方法)


文章目录

  • 1. switch-case 的缺点
  • 2. 消灭switch-case 的两种方式.
    • 2.1. 刻意定义的函数指针数组
    • 2.2. 更一般的type-handler 结构体数组
  • 3 完整的演示代码(c代码):
  • 4.程序运行结果:

1. switch-case 的缺点

switch-case语句不符合封闭性原则. 我见过一个家伙写MFC的消息分发函数,写了几千行.
显著的毛病有2个

  1. 一个函数的代码太长, 看不见头尾. 这样你难以把握整体意思.
  2. 函数封闭不了,一旦要添加一个消息,或者修改一个消息,又要改这个大函数.

2. 消灭switch-case 的两种方式.

2.1. 刻意定义的函数指针数组

把消息的处理部分定义成一个个函数, 把这些函数地址组织成一个数组.
即func_array[]={handler1,handler2,…}
就是说知道了type, 则从func_array[type] 处,要刚好能拿到其对应的handler.
这要求type从0开始,并且type还连续, 并且你还要把type对应的handler,正好放到
func_array 数组的对应位置处.
用法示例:
// 函数指针数组
void (*func_array[])(void) = {case_0, case_1, case_2};
int array_size = sizeof(func_array) / sizeof(func_array[0]);

// 使用函数指针数组 if (type >= 0 && type < array_size) { func_array[type](); } else { default_case(); }

2.2. 更一般的type-handler 结构体数组

没有那么多正好, type可能是随便定义的, 那应该用结构数组来代替函数数组.
让每一种type,都对应一个handler,构建成结构数组.
以后根据类型type, 就能找到对应的handler, 这是更一般的应对散转类型的方式
用法示例:
// 方法2: 定义结构体(适用于不连续值)
typedef struct {
int type;
void (*func)(void);
} switch_case_t;

//定义查找表 switch_case_t switch_table[] = { {0, case_0}, {5, case_1}, {10, case_2} }; int table_size = sizeof(switch_table) / sizeof(switch_table[0]); // 根据type,查找对应的处理函数,并执行之 int found = 0; for (int i = 0; i < table_size; i++) { if (switch_table[i].type == type) { switch_table[i].func(); found = 1; break; } } if (!found) { //未找到,执行默认选项 default_case(); }

为什么我们能够消灭switch-case, 是怎样消灭的switch-case. 我常常问自己.
因为我们把handler 组织了起来, 我们通过查找一个数组或者链表找到handler
而这个查找的过程用的是遍历,没有用switch-case, 找到了hander,则执行handler,
用此法消灭了swich-case.

3 完整的演示代码(c代码):

$catcase.c#include<stdio.h>// 定义处理函数voidcase_0(){printf("执行 case 0\n");}voidcase_1(){printf("执行 case 1\n");}voidcase_2(){printf("执行 case 2\n");}voiddefault_case(){printf("执行默认情况\n");}intmain(){inttype=1;// 方法1: 使用函数指针数组(适用于连续值)// 精心构建一个函数指针数组,让func_array[type]就存储有对应的handlervoid(*func_array[])(void)={case_0,case_1,case_2};intarray_size=sizeof(func_array)/sizeof(func_array[0]);// 使用函数指针数组if(type>=0&&type<array_size){func_array[type]();}else{default_case();}// 方法2: 定义结构体(更一般的情况)typedefstruct{inttype;void(*func)(void);}switch_case_t;//定义查找表switch_case_t switch_table[]={{0,case_0},{5,case_1},{10,case_2}};inttable_size=sizeof(switch_table)/sizeof(switch_table[0]);// 查找匹配项intfound=0;for(inti=0;i<table_size;i++){if(switch_table[i].type==type){switch_table[i].func();found=1;break;}}if(!found){default_case();}return0;}

4.程序运行结果:

$ ./case
执行 case 1
执行默认情况

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 13:47:32

MinerU处理超大PDF崩溃?显存溢出OOM解决方案实战

MinerU处理超大PDF崩溃&#xff1f;显存溢出OOM解决方案实战 1. 问题背景&#xff1a;当MinerU遇到几百页的PDF 你有没有试过用MinerU提取一份300页的技术手册&#xff0c;结果刚跑两分钟就提示“CUDA out of memory”直接崩了&#xff1f;这几乎是每个用MinerU做PDF结构化提…

作者头像 李华
网站建设 2026/6/15 13:44:37

汽车供应链平台如何通过CKEditor实现Excel数据透视表导入?

富文本编辑器Word粘贴功能集成技术日志 2023年X月X日 | 湖南某软件公司前端组 记录人&#xff1a;前端工程师 一、需求分析 1.1 核心需求 Word粘贴功能&#xff1a;支持从Word&#xff08;.doc/.docx&#xff09;复制内容粘贴到CKEditor 4&#xff0c;保留样式&#xff08;表…

作者头像 李华
网站建设 2026/6/14 16:45:58

bfloat16精度训练有多快?实测Qwen2.5-7B性能表现

bfloat16精度训练有多快&#xff1f;实测Qwen2.5-7B性能表现 你有没有试过在单张消费级显卡上微调一个7B级别的大模型&#xff1f;不是“理论上可行”&#xff0c;而是真正从敲下第一个命令开始&#xff0c;到看到模型说出“我由CSDN迪菲赫尔曼开发”——整个过程只用十分钟&a…

作者头像 李华
网站建设 2026/6/15 13:42:28

自定义输出路径:BSHM轻松指定你的文件夹

自定义输出路径&#xff1a;BSHM轻松指定你的文件夹 在使用AI模型进行图像处理时&#xff0c;一个常见但容易被忽视的问题是——生成的文件到底存到哪里去了&#xff1f;尤其是当你需要批量处理图片或集成到工作流中时&#xff0c;无法自定义输出路径会成为效率瓶颈。今天我们…

作者头像 李华
网站建设 2026/6/15 12:22:52

YOLO26 GitHub仓库克隆:源码二次开发准备教程

YOLO26 GitHub仓库克隆&#xff1a;源码二次开发准备教程 你是不是也遇到过这样的情况&#xff1a;想基于最新版YOLO模型做定制化改进&#xff0c;却卡在环境配置、代码拉取、目录结构梳理这些基础环节&#xff1f;明明只是想改几行代码&#xff0c;结果花半天时间折腾conda环…

作者头像 李华
网站建设 2026/6/15 12:18:36

参数调优秘籍:Live Avatar生成速度与质量双提升

参数调优秘籍&#xff1a;Live Avatar生成速度与质量双提升 1. 引言&#xff1a;在有限资源下实现最佳效果 你是否也遇到过这样的情况&#xff1f;明明已经按照官方文档配置好了环境&#xff0c;但在运行 Live Avatar 这个强大的开源数字人模型时&#xff0c;却频频遭遇显存不…

作者头像 李华