测试代码
#include <stdio.h>
int main()
{
char a[5][3];
printf("a = %p\n", a);
printf("&a[0] = %p\n", &a[0][0]);
printf("&a = %p\n", &a);
printf("*a = %p\n", *a);
return 0;
}
它被编译并以C模式(http://ideone.com/KD9Wz1)给出输出:
a = 0xbfd8ea51
&a[0] = 0xbfd8ea51
&a = 0xbfd8ea51
*a = 0xbfd8ea51
使用严格的C99模式(http://ideone.com/iTACGZ)进行编译时,会导致编译错误:
prog.c: In function ‘main’:
prog.c:7:10: error: format ‘%p’ expects argument of type ‘void *’, but argument 2 has type ‘char (*)[3]’ [-Werror=format]
prog.c:9:10: error: format ‘%p’ expects argument of type ‘void *’, but argument 2 has type ‘char (*)[5][3]’ [-Werror=format]
cc1: all warnings being treated as errors
上述代码在C99中是否有效?
答案 0 :(得分:5)
您需要为除void*
之外的任何指针向char*
插入显式转换,因为标准保证字符指针和void指针具有相同的表示形式:
6.2.5.27:指向
void
的指针应具有与指向字符类型的指针相同的表示和对齐要求。
您的C89程序存在同样的问题,但编译器无法捕获它。
以下是修复:
printf("a = %p\n", (void*)a);
printf("&a[0] = %p\n", &a[0][0]);
printf("&a = %p\n", (void*)&a);
printf("*a = %p\n", *a);