我们在挨个儿输出一个数组中的元素时,最常用的就是用一个for循环来实现,简单了事。比如类似下面的代码片段:

for(i = 0; i< length; i++)

{

printf(“数组元素是%d”, 数组[i]);

}

用一个下标索引变量i来遍历整个数组,length是数组的长度。当然了,length得提前计算出来,计算的方式有很多,很多朋友会想到用sizeof计算。不过,sizeof好归好,但是也要睁大你的双眼,小心用错,你若不信,请继续往下看。

先看传统的做法,代码如下:

#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;
}

最简单的方法就是写死了数组长度,再用一个循环挨个儿输出。程序清晰易懂,结果是:


结果也是清晰易懂。有的朋友会突发奇想,为何不这样来做:

#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;
}
增加了一个指针变量p,指针变量p的初始值是数组首元素的地址。有的朋友企图用sizeof(p)来获取数组长度,这是不对的,请看结果:



从结果可以看到,sizeof(p)其实计算的是指针变量p的类型的大小。指针p的类型是指向整数类型的指针,因此其大小为4,所以这样做是不对的。(这段话有知友指出描述错误。作者在文末已作出更新。感谢这位知友。)

我还见过有朋友这样用sizeof的,代码如下:

#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;
}

这次代码又修改了一下,将数组名number传给函数print,并且print函数的形参看上去像是一个数组。运行结果是


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


==========================2017年1月22日更新===============

感谢知友 梦人亦冷 指出文中描述的一个错误的地方。

文中描述有如下描述:

”从结果可以看到,sizeof(p)其实计算的是指针变量p的类型的大小。指针p的类型是指向整数类型的指针,因此其大小为4“

此处做如下更正:

”从结果可以看到,sizeof(p)其实计算的是指针变量p的大小。在32位系统上,不管指针p指向的是整型数据,还是字符型数据,short型数据,long型数据等,指针p本身所占的内存字节数均为4。也就是要使用4个字节的大小来存储变量p的值。“


posted on 2017-02-19 20:10  C语言答疑课堂  阅读(573)  评论(0编辑  收藏  举报