相关疑难解决方法(0)

为什么我不能将函数指针转换为(void*)?

我有一个函数,它接受一个字符串,一个字符串数组和一个指针数组,并在字符串数组中查找字符串,并从指针数组中返回相应的指针.因为我将它用于几个不同的东西,指针数组被声明为(void*)的数组,并且调用者应该知道实际上有什么类型的指针(因此它返回的返回值是什么类型的指针) ).

但是,当我传入一个函数指针数组时,在编译时会收到警告-Wpedantic:

铛:

test.c:40:8: warning: assigning to 'voidfunc' (aka 'void (*)(void)') from 'void *' converts
      between void pointer and function pointer [-Wpedantic]
Run Code Online (Sandbox Code Playgroud)

GCC:

test.c:40:8: warning: ISO C forbids assignment between function pointer and ‘void *’ [-Wpedantic]
   fptr = find_ptr("quux", name_list, (void **)ptr_list,
Run Code Online (Sandbox Code Playgroud)

这是一个测试文件,尽管警告确实正确打印"quux":

#include <stdio.h>
#include <string.h>

void foo(void)
{
  puts("foo");
}

void bar(void)
{
  puts("bar");
}

void quux(void)
{
  puts("quux");
}

typedef void (* voidfunc)(void);

voidfunc ptr_list[] = {foo, bar, quux};

char *name_list[] = {"foo", "bar", …
Run Code Online (Sandbox Code Playgroud)

c pointers function-pointers

11
推荐指数
4
解决办法
7897
查看次数

将函数指针转换为 uintptr_t / intptr_t 无效吗?

Microsoft 对 C 和 C++ 的扩展

要执行相同的转换并保持 ANSI 兼容性,您可以在将函数指针转换uintptr_t为数据指针之前将其转换为 a:

int ( * pfunc ) ();
int *pdata;
pdata = ( int * ) (uintptr_t) pfunc;
Run Code Online (Sandbox Code Playgroud)

C 的基本原理,修订版 5.10,2003 年 4 月:

即使使用显式强制转换,将函数指针转换为对象指针或 void 指针也是无效的,反之亦然

C11:

7.20.1.4 能够保存对象指针的整数类型

是否意味着pdata = ( int * ) (uintptr_t) pfunc;无效?

正如史蒂夫·萨米特所说

C 标准的编写假设指向不同对象类型的指针,尤其是指向函数而不是对象类型的指针,可能具有不同的表示形式

虽然pdata = ( int * ) pfunc;会导致UB,但似乎会pdata = ( int * ) (uintptr_t) pfunc;导致IB。这是因为“任何指针类型都可以转换为整数类型”和“整数可以转换为任何指针类型”并且uintptr_t …

c type-conversion visual-c++ language-lawyer c11

6
推荐指数
1
解决办法
1244
查看次数