作者|釜薪君
公众号|嵌入式杂牌军
前言
今天给小伙伴们带来一段简短的代码,简短但精致,将字符串与功能宏进行绑定,这样做的好处是调整代码比较方便,掌握后你就会明白什么才是结构清晰,阅读过程中如果有什么问题,可以后台留言哈!
一、代码原理说明
利用switch和case的散转功能,用宏作为散转条件,每一个宏对应一种功能,将宏和字符串进行绑定,这样通过比较字符串的方式,就能获得对应宏的功能代码。
此代码的好处是宏代码不用变的情况下,字符串和功能宏的对应是可以根据需要进行随意调整的。
二、实现源码
1.实现代码
一切说明,尽在注释中啦!代码可以理解为等级评定吧,实际意义不大,大家多关注这个小代码的结构吧!
#include <stdio.h>
#include <stdlib.h>
// 功能宏散转编号
#define ONE_STAR 1
#define TWO_STAR 2
#define THREE_STAR 3
#define FOUR_STAR 4
#define FIVE_STAR 5
#define ZERO 0 // 无效输入返回值
/* 定义查找对应表结构及查找表数组 */
static struct lookuptable
{
char *str; // 指向字符串
int code; // 对应宏功能码
}tab[]= {
// 字符串口与功能指示红的对应表,可以根据需要随意调整,下面的1-5可以换为任意字符串,只是输入时(查找时)也要一一对应上
{"1", ONE_STAR},
{"2", TWO_STAR},
{"3", THREE_STAR},
{"4", FOUR_STAR},
{"5", FIVE_STAR}
};
// 查找函数声明
SearchFunc(char *s);
int main(int argc, char *argv[])
{
int score = 0;
char str[10] = "\0";
printf("Please input number 1-5 to evaluate: ");
gets(str);
// 根据星级进行处理,这里就是简单的赋值,实际应用中可以根据需要更多
switch(SearchFunc(str))
{
case ONE_STAR:
{
score += 1;
break;
}
case TWO_STAR:
{
score += 2;
break;
}
case THREE_STAR:
{
score += 3;
break;
}
case FOUR_STAR:
{
score += 4;
break;
}
case FIVE_STAR:
{
score += 5;
break;
}
case ZERO: // 无效的情况,打印无效提升
{
printf("\nYour input is invaild!\n");
break;
}
}
// 输入有效才进行星级打印
if(SearchFunc(str)!=ZERO)
{
printf("\nThe score is: %d\n",score);
}
return 0;
}
/* 宏功能查找函数 */
SearchFunc(char *s)
{
int i;
for(i=0; i< sizeof(tab)/sizeof(tab[0]); i++)
{
if(strcmp(tab[i].str, s)==0)
{
return tab[i].code;
}
}
return ZERO; // 输入不再范围内标记为0
}
2.运行结果
运行环境Dev-C++。
① 输入值在有效范围1-5时,结果如下:
② 输入值不在有效范围内时,结果如下:
总结
将字符串与功能宏进行绑定,有利于代码调整,并能使代码更加清晰结构清晰。
欢迎关注公众号~