模块化编程,三个宏定义既对外公开程序也用,如何规划?

2020-01-13 18:25发布

我想把红外解码程序模块化,程序void ir_nec_decode(int8_t *decode_status,int8_t *nec_code)包括两个指针,*decode_status输出解码结果GET_NEC_NULL /GET_NEC_1ST_CO/DE GET_NEC_REP_CODE ;nec_code输出解码结果的4字节数组。
其中头文件:
  1. #define GET_NEC_NULL        0
  2. #define GET_NEC_1ST_CODE    1
  3. #define GET_NEC_REP_CODE    2


  4. extern void ir_nec_decode(int8_t *decode_status,int8_t *nec_code);
复制代码当中几个宏定义:
  1. #define GET_NEC_NULL        0
  2. #define GET_NEC_1ST_CODE    1
  3. #define GET_NEC_REP_CODE    2
复制代码我既要对外开放,程序ir_nec_decode中也需要用到。
如果在.h和.c中都写一遍
或者.c中include自身这个.h一次
都感觉不符合模块化的原则。
这种情况应该如何处理?


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
flamma
1楼-- · 2020-01-14 13:40
这种写成enum不是更安全的做法吗?
neutronlmk
2楼-- · 2020-01-14 17:38
flamma 发表于 2019-4-1 18:11
这种写成enum不是更安全的做法吗?

我用开部分台系OTP,他们C编译器不支持enum。
neutronlmk
3楼-- · 2020-01-14 21:34
zhugean 发表于 2019-4-1 16:04
我们模块化的规定就是必须包含自己的头文件

昨天晚上查了,包含自身头文件是为了让编译器检查声明的函数原型,谢谢。
继续请教:
.h适宜include硬件部分头文件吗?还是建议在.c里面做?
全局变量允许其它.c调用,这些变量建议.h中还是在.c中定义?
albert_w
4楼-- · 2020-01-14 23:35
本帖最后由 albert_w 于 2019-4-3 09:54 编辑
neutronlmk 发表于 2019-4-3 09:35
昨天晚上查了,包含自身头文件是为了让编译器检查声明的函数原型,谢谢。
继续请教:
.h适宜include硬件 ...


变量定义需要做到c里面, 不然多次include(被不同的C文件)就报错了, 因为这导致每个C文件里面都定义一次这个变量. h里面只能够extern int xxx(变量, 不是说函数, 所有函数声明默认都是extern的)
albert_w
5楼-- · 2020-01-15 01:22
 精彩回答 2  元偷偷看……
zhanan
6楼-- · 2020-01-15 04:33
你把这几个宏定义单独放到一个.h文件中,哪里要用到,就用include包含进去。再说你的才这么三个宏定义,怎么搞都行吧。