你确定这返回4吗,
如果是64位系统上,应该返回2;sizeof(array)=8,sizeof(* array)=4
32位系统上应该返回1.sizeof(array)=4,sizeof(* array)=4
sizeof不是函数,而是编译器预定义的宏,它在编译时确定,而不是运行时。
因此它的计算依赖上文,而在该函数中array的上文就是int * array。
直接sizeof(array)相当于sizeof(int* )。即计算int类型的指针长度,64系统上指针长度为8字节,32位系统上指针长度为4字节。
而sizeof(* array)相当于sizeof(int)。其值是4字节。
用sizeof无法计算数组长度,因为它根本就不是用来计算数组长度的,它是用来计算某个结构所占的内存空间。
使用如下方法
int array[10];
sizeof(array)
它返回的是40,而不是10。表示整个array数组占40个字节。
注意,这里返回40而不是把array当做指针看;是因为这里有了array的上文int array[10]。编译器很清楚这个array占了多少空间,因为这部分空间是编译时确定的。
但是在函数arrayLen中,编译器根本不知道参数array是从什么地方传进来的,它的内存到底是编译时确定的还是动态分配的也无法知道。因此array只能当做指针来处理。
C语言中数组的长度需要你自己维护;就是需要你自己记录数组长度。