我想让函数 A()
调用 B()
作为内联宏,但我不想要 B()
对世界可见。我只希望 A()
可见,如果用户不小心使用了 B()
,我希望出现编译错误。
我知道如何在没有内联的情况下做到这一点:
// a.h
void A(void);
// a.c
#include "b.h"
void A(void) { B(); }
如果我 #include "a.h"
,那么我可以访问 A()
但不能访问 B()
。没关系;这就是我想要的。
现在我想做同样的事情,但通过将 B
内联到 A
中来降低一级调用复杂度,但我想隐藏 B
.
// a.h
#include "b.h"
#define A() B()
#uninclude "b.h" <----This is bogus, but I want the equivalent.
// main.c
#include "a.h"
A(); <-- ok
B(); <-- undefined function
这是针对低级固件的,其中调用开销确实有所不同,但我不想仅仅为了效率而放弃高级代码管理。在 C++ 中,这是微不足道的,但我正在寻找 cpp
hack 以在纯 C 中完成它。
(在我的例子中,a
代表一个 HAL,b
代表一个 BSP。HAL 是处理器特定的,而 BSP 是板(PCB)特定的)
最佳答案
如果 b.h
所做的唯一声明是 B
的声明而不是定义,那么您可以在 a.h
中执行此操作:
// a.h
static inline void A(void)
{
#undef _B__H_ //need this if you have more than one of these inline declarations
#include "b.h"
B();
}
假设 b.h
看起来像这样:
// b.h
#ifndef _B_H_
#define _B_H_
void B(void);
#endif
那么 B
的声明仅在 A
范围内。
在 a.c
中,确保包含 b.h
before a.h
(或者做 #undef _B_H_
强制重新加载 b.h
)。否则,您将收到有关不兼容范围的警告或错误。 (a.h
在本地范围内包含 b.h
,而 a.c
在文件范围内包含 b.h
然后忽略所有剩余的本地范围包括。)
如果 b.h
进行额外的声明,只要它们在函数体的范围内是可接受的,这也将起作用。
关于c - 如何 "undeclare"函数原型(prototype)或隐藏函数原型(prototype)或#uninclude header ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19236931/