C语言——惊天BUG

惊天BUG:数组作为函数参数的时候,会被隐式转换成一个指向首元素的指针
                   sizeof(指针)结果在32位系统下就是4

为了便于理解,我用一个例题来说明

例题:在整型数组中查找指定的数字

源代码:

#include<stdio.h>
#include<stdlib.h>
int main() {
 int arr[] = { 1,3,4,5,7,9 };
 int to_find = 9;
 int i = 0;
 for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) {
  if (arr[i] == to_find) {
   break;
  }
 }
 if (i < sizeof(arr) / sizeof(arr[0])) {
  printf("找到了!下标为%d\n", i);
 }
 else {
  printf("没找到!\n");
 }
 system("pause");
 return 0;
}

运行结果:
C语言——惊天BUG

这里可以看到使用了(i < sizeof(arr) / sizeof(arr[0]) 这样就避免了去数数组元素的个数
但是当我们把上述代码封装成函数形式时,结果会不一样的

源代码:

#include<stdio.h>
#include<stdlib.h>
int Find(int arr[], int to_find) {
 int i = 0;
 for (i = 0; i < sizeof(arr) / sizeof(arr[0]);i++) {
  if (arr[i] == to_find) {
   return i;
  }
 }
 return -1;
}
int main() {
 int arr[] = { 1,3,4,5,7,9 };
 int to_find = 9;
 int i = Find(arr, to_find);
 if (i == -1) {
  printf("没找到!\n");
 }
 else {
  printf("找到了!下标为%d\n", i);
 }
 system("pause");
 return 0;
}

运行结果:
C语言——惊天BUG

这是因为C语言中存在的惊天BUG
数组作为函数参数的时候,会被隐式转换成一个指向首元素的指针
sizeof(指针)结果在32位系统下就是4

我们可以在第四行后面加一个语句来验证
printf("%d\n", sizeof(arr));
运行结果:
C语言——惊天BUG

可以看到运行的结果并不是我们想要的6,而是4
为了避免出现这种BUG情况,我们可以重新定义一个变量size在main函数中让变量size=sizeof(arr) / sizeof(arr[0])
则变量size就表示数组元素的个数

源代码(避免出现BUG的新方法):

#include<stdio.h>
#include<stdlib.h>
int Find(int arr[], int size, int to_find) {
 int i = 0;
 printf("%d\n", size);
 for (i = 0; i < size; i++) {
  if (arr[i] == to_find) {
   return i;
  }
 }
 return -1;
}
int main() {
 int arr[] = { 1,3,4,5,7,9 };
 int to_find = 9;
 int size = sizeof(arr) / sizeof(arr[0]);
 int i = Find(arr, size, to_find);
 if (i == -1) {
  printf("没找到!\n");
 }
 else {
  printf("找到了!下标为%d\n", i);
 }
 system("pause");
 return 0;
}

运行结果:
C语言——惊天BUG

可以看到了我们想要的数组元素个数为6,且找到了数字。