在以下数组中:
float mat[2][2] = {{4.0, 3.0}, {2.0, 1.0}};
我不确定以下表达式的类型和值是什么:
"*mat"
"mat[0]"
"**mat"
"**(mat+1)"
当我尝试运行它时,它总是输出地址。我现在有点困惑,因为我不知道这是否正确。
最佳答案
您有一个二维数组mat
。
*mat
和 mat[0]
是相同的,它们是(指向)第一个一维数组 {4.0, 3.0}
.
mat[1]
将是指向第二个一维数组的指针。
**mat
是第一个一维数组的第一个值:4.0
。
*(mat + 1)
是 mat[1]
,第二个一维数组,因此 **(mat + 1)
是第二个一维数组的第一个值:2.0
。
#include <stdio.h>
int main(void) {
float mat[2][2] = {{4.0, 3.0}, {2.0, 1.0}};
printf("%p\n", (void*)*mat);
printf("%p\n", (void*)mat[0]);
printf("%f\n", **mat);
printf("%f\n", **(mat+1));
return 0;
}
将打印
0x7ffc9cc9e290
0x7ffc9cc9e290
4.000000
2.000000
前两个值是数组的地址,该值可以不同,但必须相等。
关于c - 与数组访问混淆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55896867/