gpt4 book ai didi

c - 如何 "undeclare"函数原型(prototype)或隐藏函数原型(prototype)或#uninclude header

转载 作者:太空宇宙 更新时间:2023-11-04 07:24:42 25 4
gpt4 key购买 nike

我想让函数 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com