news 2026/4/13 15:30:52

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/4/10 21:36:11

实测SGLang的Tool Call功能,调度效率提升13.9%

实测SGLang的Tool Call功能&#xff0c;调度效率提升13.9% 在构建AI Agent或复杂对话系统时&#xff0c;大模型不仅要回答问题&#xff0c;还要能理解用户意图、规划任务步骤、调用外部工具。这类需求催生了“Tool Call”&#xff08;工具调用&#xff09;能力——让LLM像程序…

作者头像 李华
网站建设 2026/4/10 13:36:56

告别复杂配置!SenseVoiceSmall开箱即用的AI体验

告别复杂配置&#xff01;SenseVoiceSmall开箱即用的AI体验 你是否还在为语音识别模型部署繁琐、依赖难装、接口复杂而头疼&#xff1f; 有没有一种方式&#xff0c;能让我们像打开家电一样&#xff0c;“插电即用”地体验前沿AI语音技术&#xff1f; 今天要介绍的 SenseVoic…

作者头像 李华
网站建设 2026/4/11 3:25:46

Llama3-8B适合初创公司吗?低成本落地实战分析

Llama3-8B适合初创公司吗&#xff1f;低成本落地实战分析 1. 为什么Llama3-8B是初创团队的高性价比选择&#xff1f; 对于资源有限、追求快速验证产品方向的初创公司来说&#xff0c;AI模型的选型必须兼顾性能、成本与可商用性。在当前开源大模型中&#xff0c;Meta-Llama-3-…

作者头像 李华
网站建设 2026/4/9 0:09:32

录音真伪鉴别利器:CAM++相似度判定实战应用

录音真伪鉴别利器&#xff1a;CAM相似度判定实战应用 在日常工作中&#xff0c;你是否遇到过这些场景&#xff1a;一段关键会议录音被质疑真实性&#xff0c;客户提供的语音证据需要核实说话人身份&#xff0c;或是企业内部需要快速验证员工语音权限&#xff1f;传统方式往往依…

作者头像 李华
网站建设 2026/3/27 9:30:50

攻克纺织品质检三大痛点:AI验布机如何一站式解决方案

在纺织品生产领域&#xff0c;质量控制面临着普遍且顽固的痛点。传统方法往往陷入效率低下、标准不一、数据缺失的困境。AI验布机&#xff0c;正是针对这些核心痛点而生的智能化一站式解决方案。痛点一&#xff1a;漏检率高&#xff0c;质量风险不可控。人工验布受疲劳、情绪、…

作者头像 李华
网站建设 2026/3/31 11:46:32

PyTorch预装库版本如何查?pip list实战操作步骤

PyTorch预装库版本如何查&#xff1f;pip list实战操作步骤 1. 为什么查预装库版本是开发第一步&#xff1f; 刚拿到一个预配置好的PyTorch开发环境镜像&#xff0c;比如你手上的这个“PyTorch-2.x-Universal-Dev-v1.0”&#xff0c;第一反应不该是急着跑模型&#xff0c;而是…

作者头像 李华