我在试着了解sizeof操作员的工作原理,结果发现this
问题。下面是这个问题的代码
#include <stdio.h>
int main() {
int i = 0;
int a[i];
printf("%zu\n",sizeof(a[i++]));
printf("%d\n",i); // Here, print 0 instead of 1
return 0;
}
这里的数组a是可变长度的,但是当它用作sizeof运算符的oprand时,变量
i
不会递增。一些评论和回答说
a[i++]
不是VLA类型,并建议op应该使用2D VLA来观察副作用(sizeof evalutes its oprand)。我不清楚为什么
a[i++]
不符合VLA表达式的条件,我认为这与我们可以在传递函数的同时不指定数组的第一维有关。所以问题是什么是VLA表达式?
最佳答案
我不清楚为什么a[i++]
不能作为VLA表达式a[n]
不是VLA表达式,即使a
是VLA,因为表达式生成的是VLA的单个元素,而不是VLA本身。
一般来说,什么是VLA表达式?
在您的示例中,a
将是一个VLA表达式,因为它表示一个可变长度数组。
2D VLA将提供一个场景,其中sizeof
将计算其操作数:
int x, y;
scanf("%d %d", &x, &y);
int a[x][y];
int i = 0;
size_t z = sizeof(a[i++]);
printf("%d %d\n", i, (int)z);
这将打印
1
,因为现在不仅a
是VLA,而且a[n]
也是VLA(demo)。关于c - VLA类型的表达是什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48995441/