我正在尝试用GCC编译器执行此操作(这可能吗?):
指定一个函数但是如果未实现则此函数指向NULL。例如:
extern void something(uint some);
如果未实现,则指向NULL值。
所以可以这样检查:
something != NULL ? something(222) : etc.;
我想通过GCC解决方案(这可以通过函数指针解决)。
答案 0 :(得分:5)
这绝对不是可移植的,但gcc可以在某些平台上使用弱符号来做到这一点。我知道这适用于Linux和* BSD,但不适用于MacOS。
$ cat weak.c
#include <stdio.h>
extern int foo(void) __attribute__((__weak__));
int
main(int argc, char **argv)
{
int x = foo ? foo() : 42;
printf("%d\n", x);
return 0;
}
$ cat weak2.c
int
foo(void)
{
return 17;
}
$ cc -o weak weak.c && ./weak
42
$ cc -o weak weak.c weak2.c && ./weak
17
$
答案 1 :(得分:2)
您可以使用GCC的weakref属性
来执行此操作extern void something(int);
static void something_else(int) __attribute__((weakref("something")));
int main()
{
if (something_else)
something_else(122);
}
如果程序中未定义something
,则弱别名something_else
的地址为零。如果定义了something
,则something_else
将成为其别名。
答案 2 :(得分:1)
基本上,您正在尝试让编译器在内存地址0(NULL
)处找到一个函数。如果没有平台/编译器特定的结构,这不能在C中完成。
但有一个问题是,为什么你会想要这样做。 C是一种静态语言,所以如果你知道在编译过程中函数永远不会存在,你可以在编译时使用预处理器告诉程序的其余部分。实际上,这些编译时间替换正是预处理器首先存在的原因。
如果你的函数存在,我会创建一个你定义的宏,如下所示:
#define THE_SOMETHING_FUNCTION_EXISTS
然后使用something == NULL
替换为#ifdef
测试的任何地方。
当然,如果函数的存在可能在运行时发生变化,那么实现所需行为的正确方法是使something
成为函数指针。