未定义的功能感应

时间:2015-03-23 12:35:44

标签: c gcc

我正在尝试用GCC编译器执行此操作(这可能吗?):

指定一个函数但是如果未实现则此函数指向NULL。例如:

extern void something(uint some);

如果未实现,则指向NULL值。

所以可以这样检查:

something != NULL ? something(222) : etc.;

我想通过GCC解决方案(这可以通过函数指针解决)。

3 个答案:

答案 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成为函数指针。