天天看点

由sizeof()引出的对数组名和指针的新认识

在C++中,数组名和指针有很多类似的地方,甚至很多时候,数组名与指针可以互相替换,我也一直以为两者没什么值得注意的区别,直到看到了一道题,才发觉自己知识的匮乏。

void UpperCase(char str[]) // 将 str 中的小写字母转换成大写字母 
{
	for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i )        
	if( 'a'<=str[i] && str[i]<='z' )            
	str[i] -= ('a'-'A' );
}  
char str[] = "aBcDe"; 
cout << "str字符长度为: " << sizeof(str)/sizeof(str[0]) << endl; 
UpperCase( str ); cout << str << endl; 
           

上面这段代码中两个sizeof的用法有问题吗?

有!函数内的sizeof有问题。根据语法,sizeof(数组名)可以测得数组的容量,所以函数外的sizeof(str)等于6,没问题。但是当数组名作为函数参数进行传递的时候,就会退化成一个指针,所以函数体里str是一个指针,而指针是4个字节,因此sizeof(str)等于4。

可以看出,数组名与指针还是有区别的,数组名并不单纯的是一个指针(数组名和指针之间有一个不同之处,指针是一个变量,但数组名不是变量)。这也是为什么数组名作为参数传递时,经常需要一个长度参数。

对于strlen来说,就没有这么多问题了,strlen本身就是一个函数(sizeof是操作符),strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值(长度不包含“\0”)。

如果还有疑问,可以参考http://www.cnblogs.com/wuzhenbo/archive/2012/05/29/2523777.html

继续阅读