数组名 别混淆了sizeof和sizeof(指针)

我们在C语言编程时挨个儿输出一个数组中的元素时 , 最常用的就是用一个for循环来实现,简单了事 。比如类似下面的C程序代码片段:
for(i = 0; i< length; i++){printf(“数组元素是%d”, 数组[i]);}用一个下标索引变量i来遍历整个C程序数组,length是数组的长度 。当然了,length得提前计算出来,计算的方式有很多 , 很多朋友会想到用sizeof计算 。不过,sizeof好归好,但是也要睁大你的双眼 , 小心用错 , 你若不信 , 请继续往下看 。
【数组名 别混淆了sizeof和sizeof(指针)】先看传统的做法,C程序代码如下:
#include "stdio.h"int main(void) {int number[5] = {1,2,3,4,5};int index = 0;printf("数组的元素分别是:\n");for(index = 0;index < 5; index++){printf("%d ", number[index]);}printf("\n");return 0;}最简单的方法就是写死了C语言数组长度,再用一个循环挨个儿输出 。程序清晰易懂 , 结果是:

数组名 别混淆了sizeof和sizeof(指针)

结果也是清晰易懂 。
有的朋友会突发奇想,为何不这样来做:
#include "stdio.h"int main(void) {int number[5] = {1,2,3,4,5};int index = 0;int *p = &number[0];printf("数组的长度是: %d\n", sizeof(p));printf("数组的元素分别是:\n");for(index = 0;index < sizeof(p); index++){printf("%d ", number[index]);}printf("\n");return 0;}增加了一个C语言指针变量p,指针变量p的初始值是数组首元素的地址 。有的朋友企图用sizeof(p)来获取数组长度 , 这是不对的,请看结果:
数组名 别混淆了sizeof和sizeof(指针)

从结果可以看到,sizeof(p)其实计算的是指针变量p的大小 。在32位系统上,不管指针p指向的是整型数据,还是字符型数据,short型数据,long型数据等,指针p本身所占的内存字节数均为4 。也就是要使用4个字节的大小来存储变量p的值 。
我还见过有朋友这样用sizeof的,C程序代码如下:
#include "stdio.h"void print(int number[5]) {int index = 0; ; printf("函数print中,数组长度是: %d ", sizeof(number));printf("函数中数组的元素分别是:\n"); for(index = 0; index < sizeof(number) / sizeof(number[0]); index++) {printf("%d ", number[index]); } printf("\n");} int main(void) {int number[5] = {1,2,3,4,5};print(number);return 0;}这次C程序代码又修改了一下,将数组名number传给函数print,并且print函数的形参看上去像是一个数组 。运行结果是
数组名 别混淆了sizeof和sizeof(指针)

诺诺,运行结果不是预期中的结果啊 。其实,C语言函数print形参看上去像是一个数组,于是有的朋友就会认为它就是一个数组,于是就发生了使用sizeof来计算数组长度;真实情况是print函数的参数还是一个指针,指针,指针 , 没错,就是一个C语言指针,所以sizeof(number)计算的还是指针的大小 。初学的朋友们一定要切记!

相关经验推荐