为啥我这里用sizeof算ar的元素个数不对呢
#include<stdio.h>
int max(int ar[]);
int main() {
int x;
x=max((int[]) {4,8,9,5,6,7,11,3});
printf("数组中的最大值是%d\n", x);
return 0;
}
int max(int *ar) {
int i=0, j=1;
printf("%d\n",sizeof(ar)/sizeof(*ar));
while (j<=sizeof(ar)/sizeof(ar)) {
if ((ar + i) < *(ar + j)) {
i = j;
}
j++;
}
return *(ar + i);
}
这里稍微测试了一下,发现这个sizeof(ar)只有4的大小,估计是去计算sizeof(&ar[0])了。
想知道为啥这里会错,是因为这里使用了复合字面量没有真正创建一个数组么
这里的ar代表的是指针,sizeof(ar)是8,sizeof(*ar)是4
整型和浮点型数组没有结束符,也不能使用'\0'来判断结束,所以需要严格控制个数,你需要将数组的个数传给max函数
代码修改参考如下:
int max(int *ar, int n) {
int i = 0, j = 1;
while (j < n) {
if (*(ar + i) < *(ar + j)) {
i = j;
}
j++;
}
return *(ar + i);
}
int main(int argc, const char * argv[]) {
int x;
x = max((int[]){1, 2, 3, 4, 5, 6, 7, 8}, sizeof((int[]){1, 2, 3, 4, 5, 6, 7, 8})/sizeof(int));
printf("%d\n", x);
return 0;
}
x=max((int[]) {4,8,9,5,6,7,11,3}); //这句代码的执行,首先会创建这个数组,然后再将指向这个数组的指针作为参数传递给int max(int ar[])函数,而不是将创建的整块内存块(即整个数组)作为参数传递给int max(int ar[])函数。所以在int max(int ar[])这个函数内部执行 sizeof(ar) (就是sizeof(指针)),在32位系统中,sizeof(指针) = 4,在64位系统中,sizeof(指针) = 8。回复中的一楼兄弟是在64系统中执行的代码,所以 sizeof(ar) = 8,楼主是在32位系统中执行的代码,所以 sizeof(ar) = 4