本文不是研究sizeof(), strlen() 的深奥定义和原理,我们不会在理论上太过钻牛角尖。希望读这篇文章的你,也不要太过抠概念(不要拘泥于语法)。我们只做 实用意义 的介绍和讨论。
在介绍字符串之前,先介绍 sizeof()操作符 、 strlen()库函数。
1.sizeof() 基本介绍
1 printf("int: %d\n", sizeof(int)); 2 printf("char: %d\n", sizeof(char)); 3 printf("int*: %d\n", sizeof(int *)); 4 printf("char*: %d\n", sizeof(char *)); 5 printf("short: %d\n", sizeof(short)); 6 printf("float: %d\n", sizeof(float)); 7 printf("double: %d\n", sizeof(double)); 8 printf("long: %d\n", sizeof(long)); 9 printf("long long: %d\n", sizeof(long long)); 10 printf("unsinged int: %d\n", sizeof(unsigned int)); 11 printf("unsigned char: %d\n", sizeof(unsigned char)); 12 printf("unsigned short: %d\n", sizeof(unsigned short)); 13 printf("unsigned long: %d\n", sizeof(unsigned long)); 14 printf("******************************************\n");
1.1 sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:
数组——编译时分配的数组空间大小;
指针——存储该指针所用的空间大小(存储该指针的地址的长度,是长整型,应该为4);
类型——该类型所占的空间大小;
对象——对象的实际占用空间大小;
函数——函数的返回类型所占的空间大小。函数的返回类型不能是void。
1.2 sizeof()的基本知识,不过多介绍。下面讲几个重点(面试题常考):
sizeof(int)的 值是 4 个字节;
sizeof(指针) 的值是 4 个字节;
sizeof(char) 的值是 1 个字节;
char szStr1[20] = {0};
int szStr2[20] = {0};
sizeof(szStr1) 结果是: 20 // 20个 char 的数组,在内存中,占用 20 * 1个 字节空间
sizeof(szStr2) 结果是: 80 // 20个 int 的数组,在内存中 占用 20 * 4 个字节空间
1.3 数组和指针的区别、 sizeof()结构体的内存对齐问题,这2个知识点先跳过,以后会讨论;有兴趣的你,可以先 百度补脑这2个比较深奥的问题。
2.strlen 基本介绍
2.1 strlen(...)是函数,要在运行时才能计算。使用strlen()的时候,需要 #include <string>
参数必须是字符型指针(char*)。当数组名作为参数传入时,实际上数组就退化成指针了。
它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符NULL。返回的长度大小不包括NULL。
2.2 计算字符长度.
char arr[] = "hello"; strlen(arr) 的结果是 5
char arr[5] = "hello"; 这样定义,编译阶段都会报错。定义一个常量字符串的时候,字符串末尾是默认的会加上一个‘\0‘结束符。因此,"hello" 字符串 需要 6个字节 的空间。
char arr[10] = "Hello"; strlen(arr) 的结果是 5 . 虽然"Hello"字符串占用了6个字节的空间,但是strlen计算长度的时候,没有将字符结束符"\0"计算在内,因此返回的长度是 5。
char arr[5] = {‘h‘, ‘e‘, ‘l‘, ‘l‘, ‘o‘}; /// 这定义的仅仅是一个字符数组,不是一个字符串(字符串后面必须有\0 结尾)
int iLen = strlen(arr); //// 因此,在使用strlen计算长度的时候,得到的结果是一个未知的整数。strlen 在内存中,从arr地址开始,不断向后找查找,直到找到 \0 才返回。
1 #include <stdio.h> 2 #include <string> 3 using namespace std; 4 void main() 5 { 6 char arr[] = "hello"; 7 int iLen = strlen(arr); 8 9 string str3 = "hello"; 10 int iLen3 = strlen(str3.c_str()); 11 printf("******************************************\n"); 12 getchar(); 13 }
strlen
3.sizeof() 和 strlen() 的区别
3.1 sizeof是算符,strlen是函数
3.2 sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以‘‘\0‘‘结尾的
3.3 数组做sizeof的参数不退化,传递给strlen就退化为指针了
3.4示例:
3.4.1 静态数组
char str[20]="0123456789";
int a=strlen(str); ///// a=10 strlen 计算字符串的长度,以结束符 0x00 为字符串结束
int b=sizeof(str); // 而 b=20 sizeof 计算的则是分配的数组 str[20] 所占的内存空间的大小,不受里面存储的内容改变。
3.4.2 指针
char* ss = "0123456789";
sizeof(ss) 结果 4 ss是指向字符串常量的字符指针,sizeof 获得的是一个指针的之所占的空间,应该是长整型的,所以是4
sizeof(*ss) 结果 1 *ss是第一个字符 其实就是获得了字符串的第一位‘0‘ 所占的内存空间,是char类型的,占了 1 个字节
strlen(ss)结果 10 要想获取一个字符串的长度,需要使用 strlen() 函数、
3.4.3 常量字符串
int iLen1 = strlen("hello"); /// iLen1=5
int iSize = sizeof("hello"); /// iSize=6 . 面试题中,容易混淆! sizeof("hello")中,"hello"被当做数组处理的,而不是指针。(知道是这么回事就OK了、具体区别,百度脑补 指针和数组的区别)
char* str3 = "hello";
int iSize3 = sizeof(str3); /// iSize3=4, sizeof(str3)计算的是一个指针所占 内存空间的大小,指针所占内存空间大小是 4个字节。
参考链接:
http://www.cnblogs.com/carekee/articles/1630789.html