c语言 x*,C语言 X宏 - 哇哈哈 - OSCHINA - 中文开源技术交流社区

有些时候我们在程序中定义一些错误码时,常常会有一个随之对应的获取错误信息的函数。比如这样:

enum ErrorCode

{

ERROR_0,

ERROR_1,

ERROR_2,

ERROR_3

};

const char* get_error_info(enum ErrorCode error_code)

{

switch(error_code)

{

case ERROR_0:

return "error info 0";

case ERROR_1:

return "error info 1";

case ERROR_2:

return "error info 2";

case ERROR_3:

return "error info 3";

}

return "";

}

还有一种方法是这样:

enum

{

ERROR_0,

ERROR_1,

ERROR_2,

ERROR_3

};

const char* error_info[] =

{

"error info 0",

"error info 1",

"error info 2",

"error info 3"

};

但以上这种方式若增加了ERROR_4后没有在error_info中增加响应内容,则造成数组下标越界!

于是有人创造了X宏的方式,这利用了C语言本身的预处理机制

test.h

#ifndef _TEST_H_

#define _TEST_H_

#define NUMBER      X(One,"One") X(Two,"Two") X(Three,"Three")

#define X(a,b)      a,

enum Number { NUMBER };

#undef X

extern const char *NumberStrings[];

#endif // _TEST_H_

test.c

#include "test.h"

#define X(a, b) b,

const char *NumberStrings[] =  {NUMBER};

#undef X

使用以上方法的时候就可以在头文件中扩展NUMBER宏的枚举和关联内容的定义。

这个技巧不局限于枚举与字符串的关联,也可以是枚举与任何类型的关联内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值