宝宝巴士emmm 发表于 2023-7-11 22:23:57

void*指针强转为int*使用后置++报错为大小未知

int a=0;

void* p = (void*) &a;

printf ("%p", (int*)p++);

return 0;



错误(活动)        E0852        表达式必须是指向完整对象类型的指针       

错误        C2036        “void *”: 未知的大小       

歌者文明清理员 发表于 2023-7-11 22:26:18

在C语言中,将void*指针强制转换为其他类型指针时,需要确保转换后的指针类型是指向完整对象类型的指针。由于void*指针本身不包含有关所指对象的大小信息,所以无法进行后置自增操作。

在你的代码中,你将一个int类型的变量的地址赋值给了void*指针,并尝试对其进行后置自增操作。这是错误的,因为后置自增操作符(++)要求操作数是指向完整对象类型的指针。

如果你想对void*指针进行自增操作,你需要先将其转换回正确的指针类型,然后再执行自增操作。例如:

int a = 0;
void* p = (void*) &a;

int* ptr = (int*)p;
ptr++;

printf ("%p", ptr);
请注意,在进行指针的转换和操作时,务必确保遵循C语言的类型规则,以避免出现未定义的行为。

宝宝巴士emmm 发表于 2023-7-11 22:48:07

歌者文明清理员 发表于 2023-7-11 22:26
在C语言中,将void*指针强制转换为其他类型指针时,需要确保转换后的指针类型是指向完整对象类型的指针。由 ...

原因是虽然转成int*类型但在条语句执行完后自增对象还是void*类型的p嘛?

歌者文明清理员 发表于 2023-7-11 22:49:08

宝宝巴士emmm 发表于 2023-7-11 22:48
原因是虽然转成int*类型但在条语句执行完后自增对象还是void*类型的p嘛?

在C语言中,后置自增操作符(++)会先使用指针的值,然后再自增指针的位置。在你的代码中,尽管你将p转换为int*类型,但是在后置自增操作完毕后,p仍然是一个void*类型的指针。

这是由于void*指针的特性决定的。对于void*指针,编译器不知道指针所指对象的大小,因此它无法确定在指针上执行自增操作应该移动多少字节。所以,对void*类型的指针进行自增操作是非法的。

如果你想要对指针进行自增操作,你需要先将void*指针转换为正确的指针类型,然后再对其进行自增操作。例如:

c
int a = 0;
void* p = (void*) &a;

int* ptr = (int*)p;
ptr++;

printf ("%p", ptr);
在这个例子中,将p转换为int*类型后,再对指针ptr进行自增操作,就能正常地使指针指向下一个int对象的位置。
页: [1]
查看完整版本: void*指针强转为int*使用后置++报错为大小未知