Sizeof与Strlen的分别与交流,整到一块
分类:计算机编程

写在前方

一、sizeof
sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编写翻译时即总计好了,参数能够是数组、指针、类型、对象、函数等。
它的效能是:获得保证能包容达成所确立的最大指标的字节大小。
是因为在编写翻译时总计,因而sizeof无法用来回到动态分配的内部存款和储蓄器空间的尺寸。实际上,用sizeof来回到类型以至静态分配的对象、结构或数组所占的空间,重回值跟对象、结构、数组所蕴藏的源委未有关系。
具体来说,当参数分别如下时,sizeof再次来到的值表示的意思如下:
数组——编译时分配的数组空间尺寸;
指南针——存款和储蓄该指针所用的长空尺寸(存款和储蓄该指针的地点的长短,是长整型,应为4);
花色——该类型所占的长空尺寸;
对象——对象的实际上占用空间大小;
函数——函数的归来类型所占的空中山高校小。函数的回来类型不能是void。

sizeof、strlen、字符串、数组,提到那几个概念,相信学过C语言的人都能耳濡目染,也能谈得井井有理,可是,在实质上接受中,当那些内容交织在一起时,我们却不料定能搞地清晰,本文的指标就是帮忙大家将相关知识总括清楚。


 

二、strlen
strlen(...)是函数,要在运作时技巧计算。参数必得是字符型指针(char*)。当数组名作为参数字传送入时,实际上数组就退化成指针了。
它的职能是:再次回到字符串的长度。该字符串恐怕是和谐定义的,也可能是内部存款和储蓄器中随机的,该函数实际到位的功力是从代表该字符串的首先个地方初步遍历,直到碰着甘休符NULL。再次来到的尺寸大小不蕴涵NULL。

正文


先看生龙活虎段代码

三、举例:
eg1、char arr[10] = "What?";
int len_one = strlen(arr);
int len_two = sizeof(arr);
cout << len_one << " and " << len_two << endl;
输出结果为:5 and 10
点评:sizeof再次回到定义arr数组时,编写翻译器为其分配的数组空间大小,不珍爱里面存了稍微数量。strlen只关怀存款和储蓄的数额内容,不关切空间的大小和品种。

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 
 4 void testchar(char str[])
 5 {
 6     printf("%d %dn", sizeof(str), strlen(str));
 7 }
 8 
 9 void testint(int arr[])
10 {
11     printf("%dn", sizeof(arr));
12 }
13 
14 int main()
15 {
16     char str[] = "abc";
17     printf("%d %dn", sizeof(str), strlen(str)); //4 3
18 
19     char str1[10] = "abc";
20     printf("%d %dn", sizeof(str1), strlen(str1)); //10 3
21 
22     char dog[] = "wangwang\0miao";
23     printf("%d %dn", sizeof(dog), strlen(dog)); //14 8
24     testchar(dog); //4 8
25 
26     char *cat = "wangwang\0miaomiao";
27     printf("%d %dn", sizeof(cat), strlen(cat)); //4 8
28     
29     int arr[10] = { 0 };
30     printf("%d %dn", sizeof(arr), sizeof(arr[11])); //40 4
31     testint(arr); //4
32 
33     return 0;
34 }
eg2、char * parr = new char[10];
          int len_one = strlen(parr);
          int len_two = sizeof(parr);
          int len_three = sizeof(*parr);
          cout << len_one << " and " << len_two << " and " << len_three << endl;
输出结果:23 and 4 and 1
点评:第一个输出结果23实际上每次运行可能不一样,这取决于parr里面存了什么(从parr[0]开始知道遇到第一个NULL结束);第二个结果实际上本意是想计算parr所指向的动态内存空间的大小,但是事与愿违,sizeof认为parr是个字符指针,因此返回的是该指针所占的空间(指针的存储用的是长整型,所以为4);第三个结果,由于*parr所代表的是parr所指的地址空间存放的字符,所以长度为1。

 


 结果

四、参谋资料:
Sizeof与Strlen的界别与联络(转)

 图片 1

1.sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。
该品种保障能宽容完毕所确立的最大目的的字节大小。

在讲授下边包车型大巴例子从前,大家先来讲一说sizeof和strlen。

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

语法上的庐山真面目目差别:

3.sizeof能够用项目做参数,strlen只好用char*做参数,且必须是以''\0''结尾的。
sizeof还是能用函数做参数,举个例子:
short f();
printf("%dn", sizeof(f()));
输出的结果是sizeof(short),即2。

sizeof是运算符,strlen是函数。

4.数组做sizeof的参数不落伍,传递给strlen就落伍为指针了。

适用范围不一样等:

5.相当多编写翻译程序 在编写翻译的时候就把sizeof总计过了 是体系或许变量的尺寸那正是sizeof(x)能够用来定义数组维数的从头到尾的经过
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而b=20;

对sizeof(name)来说,name可以是变量名也能够是项目名,对strlen来讲,参数必需是char*类别的,即strlen仅用于字符串。

6.strlen的结果要在运转的时候才具计算出来,时用来测算字符串的长短,不是种类占内部存款和储蓄器的分寸。

关键——从尾部看本质

7.sizeof后生机勃勃旦是种类必需加括弧,假若是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数。

strlen(ptr)的进行机理是:从参数ptr所针对的内部存款和储蓄器初阶向下计数,直到内部存储器中的内容是全0(即’\0’)为止(不会对’\0’进行计数)。用strlen衡量字符串的尺寸,其实便是依赖那么些规律。

8.当适用了于三个组织类型时或变量, sizeof 重返实际的大大小小,
当适用大器晚成静态地空间数组, sizeof 归还全体数组的尺寸。
sizeof 操作符不可能回去动态地被分派了的数组或外界的数组的尺码

sizeof(name)的推行机理是:假若name是多少个类型名,获得的是该类型的高低(所谓类型的分寸,指的是:借使存在贰个该品种的变量,那几个变量在内部存款和储蓄器中所占用的字节数),假如name是一个变量名,那么,sizeof(name)并不会真正采访该变量,而是先获悉该变量的项目,然后再重返该类型的分寸(即就是struct那样的复杂类型,编写翻译器在编译时也会依赖它的种种域记录其尺寸,所以,由项目获得类型大小,不是大器晚成件难事)。换句话说,本质上,sizeof的运算对象是体系。借使name是贰个变量名,那么,sizeof如何“对待”name的类别,将是八个关键难点。(前面我们会对那点有浓烈的回味)

9.数组作为参数字传送给函数时传的是指针实际不是数组,传递的是数组的首地址,
如:
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的不二等秘书诀,是放之四海皆准的法则。上面,大家就以那样的轨道来深入分析上边的事例。

小编们能常在用到 sizeof 和 strlen 的时候,平日是测算字符串数组的长短
看了地方的亲力亲为表达,发现两个的使用大概有分别的,从那个例子能够看得很精通:

a.

char str[20]="0123456789";
int a=strlen(str); //a=10; >>>> strlen 计算字符串的长度,以截止符 0x00 为字符串停止。
int b=sizeof(str); //而b=20; >>>> sizeof 计算的则是分配的数组 str[20] 所占的内部存款和储蓄器空间的朗朗上口,不受里面储存的内容改造。

char str[] = "abc";
printf("%d %dn", sizeof(str), strlen(str)); //4 3

上面是对静态数组管理的结果,要是是对指针,结果就不生机勃勃致了

此处,是用数组的样式注脚字符串,编写翻译器会自行在字符串后面加上'\0',所以,数组的因素个数是4并非3。对于sizeof(str)来说,sizeof将str视为char [4]l类型的变量,所以,sizeof(str)的结果正是百分百数组所攻下的空间尺寸。对于strlen(str)来讲,它从str指向的内部存款和储蓄器伊始计数,直到遇见全0的内部存款和储蓄器('\0'),所以最后收获结果3。

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

b.

长整型的,所以是4
sizeof(ss) 结果 1 ===》ss是第一个字符 其实正是得到了字符串的首先位'0' 所占的内部存款和储蓄器空间,是char类

char str1[10] = "abc";
printf("%d %dn", sizeof(str1), strlen(str1)); //10 3

型的,占了 1 位

 

strlen(ss)= 10 >>>> 假设要得到那些字符串的长短,则必要求接纳strlen

编写翻译器为char str1[10]分配13个数组成分大小的半空中,那与开首化它的字符串未有提到,所以sizeof(str1)获得10。

转自http://www.cnblogs.com/carekee/articles/1630789.html

c.

char dog[] = "wangwang\0miao";
printf("%d %dn", sizeof(dog), strlen(dog)); //14 8
testchar(dog); //4 8

前两句和a中的意况同样,sizeof(dog)输出整个数组所占的内部存款和储蓄器大小(饱含编写翻译器加上去的'\0'),strlen(dog)遇到'\0'就停下,所以输出8。

再看前边的函数调用,数组名dog作为函数实参传入,我们再来回想一下testchar函数

void testchar(char str[])
{
    printf("%d %dn", sizeof(str), strlen(str));
}

大家发现,这里sizeof(str)并从未像sizeof(dog)那样获得14,而是获得了4。那是因为,str是函数形参,就算它是以数组名的样式现身的,传给它的实参也真正是数组名,但sizeof仅仅把它当成三个char*品种的指针对待,所以,sizeof(str)的结果就是char *类型所占的空间4。至于strlen(str),大家后面说过,它奉行的机理正是从str指向的内存开头向下计数,直到遇见'\0',所以照旧收获8。

d.

char *cat = "wangwang\0miaomiao";
printf("%d %dn", sizeof(cat), strlen(cat)); //4 8 

由于cat明显宣示为char*,所以sizeof将它视为指针,获得4。

e.

int arr[10] = { 0 };
printf("%d %dn", sizeof(arr), sizeof(arr[11])); //40 4
testint(arr); //4

眼下说过,当数组名作为函数形参现身时,sizeof仅仅将其正是三个指针,不然,sizeof认为它象征全体数组,所以,sizeof(arr)获得全方位数组所占的字节数40,而testint(arr)的结果是int*种类的指针的长度4。

sizeof(int[11])中,很明朗数组越界了,但并不会并发运维时不当。原因是:依靠大家付出的决断法则,sizeof并未当真采访arr[11],根据arr的声明,sizeof知道arr[11]是int型的,所以回来int类型的高低。

至于testint(arr),道理和c中的testchar(dog)相同。

 

终极,基于上边包车型客车探讨,给出编码准绳:

1.永恒不要用sizeof来求字符串长度!它不是干这几个活的,所以你也恒久不会赢得正确答案。

2.不要布鼓雷门地用sizeof(arr)/sizeof(arr[0])那样的代码求数组的尺寸!sizeof亦非干这些活的。借使arr是函数形参,获得的结果将是荒谬的(除非你在31位系统下恰巧注明int arr[1]或者char arr[4]等,但那纯属巧合)。既然是数组,长度自然是已知的,求数主任度这一自个儿,正是多此一举的愚拙行为。

 

写在背后

正文的目标,就是使读者对C语言的基础知识——sizeof和strlen有一个真相的认知,同期对与之息息相关的易错、易混难题有二个不错、清晰的判定。由于在下胸无点墨,错误疏漏的地方在所无免,希望广大读者积极谈论指正,您的商量指就是在下发展的不竭引力。

本文由pc28.am发布于计算机编程,转载请注明出处:Sizeof与Strlen的分别与交流,整到一块

上一篇:概率论与数理统计,概率算法_二项分布和泊松分 下一篇:没有了
猜你喜欢
热门排行
精彩图文