void*指针强转为int*使用后置++报错为大小未知
int a=0;void* p = (void*) &a;
printf ("%p", (int*)p++);
return 0;
错误(活动) E0852 表达式必须是指向完整对象类型的指针
错误 C2036 “void *”: 未知的大小
在C语言中,将void*指针强制转换为其他类型指针时,需要确保转换后的指针类型是指向完整对象类型的指针。由于void*指针本身不包含有关所指对象的大小信息,所以无法进行后置自增操作。
在你的代码中,你将一个int类型的变量的地址赋值给了void*指针,并尝试对其进行后置自增操作。这是错误的,因为后置自增操作符(++)要求操作数是指向完整对象类型的指针。
如果你想对void*指针进行自增操作,你需要先将其转换回正确的指针类型,然后再执行自增操作。例如:
int a = 0;
void* p = (void*) &a;
int* ptr = (int*)p;
ptr++;
printf ("%p", ptr);
请注意,在进行指针的转换和操作时,务必确保遵循C语言的类型规则,以避免出现未定义的行为。 歌者文明清理员 发表于 2023-7-11 22:26
在C语言中,将void*指针强制转换为其他类型指针时,需要确保转换后的指针类型是指向完整对象类型的指针。由 ...
原因是虽然转成int*类型但在条语句执行完后自增对象还是void*类型的p嘛? 宝宝巴士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]