黑马程序员技术交流社区

标题: 34344444444444444 [打印本页]

作者: 温天恩    时间: 2014-7-14 08:39
标题: 34344444444444444
本帖最后由 温天恩 于 2014-12-11 16:09 编辑

213333333333333333333333333

作者: a1130003724    时间: 2014-7-14 08:50
一、sizeof
    sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
    它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
    由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
    具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:
    数组——编译时分配的数组空间大小;
    指针——存储该指针所用的空间大小(64位编译器下为8字节);
    类型——该类型所占的空间大小;
    对象——对象的实际占用空间大小;
    函数——函数的返回类型所占的空间大小。函数的返回类型不能是void。

格式的写法
sizeof操作符,对变量或对象可以不加括号,但若是类型,须加括号。

指针与静态数组的sizeof操作
指针均可看为变量类型的一种。64位编译器下所有指针变量的sizeof 操作结果均为8。
实例1::char *p;
sizeof(p)=8;
sizeof(*p) = 1;   //相当于sizeof(char);  
实例2:  
对于静态数组,sizeof可直接计算数组大小;
例:int a[10];
char b[]="hello";
sizeof(a)等于4*10=40;
sizeof(b)等于6;
void  fun(char p[])
{
sizeof(p);         //等于8,数组做型参时,数组名称当作指针使用!
}

**************

二、strlen
    strlen(...)是函数,要在运行时才能计算。参数必须是字符型指针(char*)。当数组名作为参数传入时,实际上数组就退化成指针了。
    它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符"\0"。返回的长度大小不包括"\0"。
*****************

三、Sizeof与Strlen的区别与联系

1.strlen计算字符数组的字符数,以"\0"为结束判断,不计算为'\0'的数组元素。
sizeof计算数据(包括数组、变量、类型、结构体等)所占内存空间,用字节数表示(当然用在字符数组计算"\0"的大小)。

2.sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。
该类型保证能容纳实现所建立的最大对象的字节大小。

3.sizeof是算符,strlen是函数。

4.sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以''\0''结尾的。
sizeof还可以用函数做参数,比如:
short f();
printf("%d\n", sizeof(f()));
输出的结果是sizeof(short),即2。

5.数组做sizeof的参数不退化,传递给strlen就退化为指针了。

6.大部分编译程序 在编译的时候就把sizeof计算过了 是类型或是变量的长度这就是sizeof(x)可以用来定义数组维数的原因
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而b=20;

7.strlen的结果要在运行的时候才能计算出来,时用来计算字符串的长度,不是类型占内存的大小。

8.sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数。

9.当适用了于一个结构类型时或变量, sizeof 返回实际的大小,
当适用一静态地空间数组, sizeof 归还全部数组的尺寸。
sizeof 操作符不能返回动态地被分派了的数组或外部的数组的尺寸

10.数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,
如:
fun(char [8])
fun(char [])
都等价于 fun(char *)
在C++里参数传递数组永远都是传递指向数组首元素的指针,编译器不知道数组的大小
如果想在函数内知道数组的大小, 需要这样做:
进入函数后用memcpy拷贝出来,长度由另一个形参传进去
fun(unsiged char *p1, int len)
{
unsigned char* buf = new unsigned char[len+1]
memcpy(buf, p1, len);
}

我们能常在用到 sizeof 和 strlen 的时候,通常是计算字符串数组的长度
看了上面的详细解释,发现两者的使用还是有区别的,从这个例子可以看得很清楚:

char str[20]="0123456789";
int a=strlen(str); //a=10; >>>> strlen 计算字符串的长度,以结束符 0x00 为字符串结束。
int b=sizeof(str); //而b=20; >>>> sizeof 计算的则是分配的数组 str[20] 所占的内存空间的大小,不受里面存储的内容改变。

上面是对静态数组处理的结果,如果是对指针,结果就不一样了

char* ss = "0123456789";
sizeof(ss) 结果 4 ===》ss是指向字符串常量的字符指针,sizeof 获得的是一个指针的之所占的空间,应该是

长整型的,所以是4
sizeof(*ss) 结果 1 ===》*ss是第一个字符 其实就是获得了字符串的第一位'0' 所占的内存空间,是char类

型的,占了 1 位

strlen(ss)= 10 >>>> 如果要获得这个字符串的长度,则一定要使用 strlen
作者: 温天恩    时间: 2014-7-14 08:56
a1130003724 发表于 2014-7-14 08:50
一、sizeof
    sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可 ...

回答好详细,非常感谢!
作者: Moebius    时间: 2014-7-14 12:39
回答得好详细!
作者: x65396731    时间: 2014-7-14 16:26
貌似一个算字符数,一个是算字节数,会计算一个\0
作者: 云霄之上    时间: 2014-7-14 18:33
strlen是一个函数  如果你要调用这个函数那么你就必须在头文件里面加上#include <string.h> 这是一个计算字符数量的函数  而 sizeof是一个计算字节数的 函数 但是不用调用#include<string.h>  两者根本上计算的不是一个概念的东西
作者: zhs    时间: 2014-7-14 19:25
sizeof是运算符,计算变量或数据类型的字节数。
使用注意:计算变量可以不写(),计算数据类型必须写。
strlen是一个函数,计算字符串的字符数(字节数),直到'ç结束。
使用注意:
1.strlen计算字符串长度时直到遇到'\0'才结束。
2.strlen函数计算字符串时'\0'不计算在长度之内。
3.记得#include <stirng.h>
作者: 温天恩    时间: 2014-7-14 20:10
zhs 发表于 2014-7-14 19:25
sizeof是运算符,计算变量或数据类型的字节数。
使用注意:计算变量可以不写(),计算数据类型必须写。
strl ...

了解了,谢谢了!
作者: 温天恩    时间: 2014-7-14 20:12
zhs 发表于 2014-7-14 19:25
sizeof是运算符,计算变量或数据类型的字节数。
使用注意:计算变量可以不写(),计算数据类型必须写。
strl ...

了解了,谢谢了!
作者: 周田金    时间: 2014-7-14 20:33
过来学习学习~
作者: zhs    时间: 2014-7-14 22:00
温天恩 发表于 2014-7-14 20:12
了解了,谢谢了!

共同进步




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2