1. sizeof
sizeof(…)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:
数组——编译时分配的数组空间大小;
指针——存储该指针所用的空间大小(存储该指针的地址的长度,是长整型,应该为4);
类型——该类型所占的空间大小;
对象——对象的实际占用空间大小;
函数——函数的返回类型所占的空间大小。函数的返回类型不能是void。
2. strlen
strlen(…)是函数,要在运行时才能计算。参数必须是字符型指针(char*)。当数组名作为参数传入时,实际上数组就退化成指针了。
它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符NULL。返回的长度大小不包括NULL。
函数返回字符数组事例:
#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
void functest(char *p)
{
char *temp = "yangdiao";
printf("sizeof(temp):%d\n",sizeof(temp));//该行的打印结果为 4
printf("strlen(temp):%d\n", strlen(temp));
memcpy(p,temp,strlen(temp));
}
int main()
{
char a[30];
printf("sizeof(a):%d\n",sizeof(a));
printf("strlen(a):%d\n",strlen(a));
memset(a,0,sizeof(a));
functest(a);
while (1);
return 0;
}
结果:
sizeof(a):30
strlen(a):43
sizeof(temp):4
strlen(temp):8
3. sizeof(string)
上面的事例代码中,sizeof(temp)返回的值是 4,而不是我们想要的 8,这是什么原因呢?
string的实现在各库中可能有所不同,但是在同一库中相同一点是,无论你的string里放多长的字符串,它的sizeof()都是固定的,字符串所占的空间是从堆中动态分配的,与sizeof()无关。
sizeof(string)=4可能是最典型的实现之一,不过也有sizeof()为12、32字节的库实现。 但是VC6.0测试后sizeof(string)=16.还是跟编译器有关。
参考:
http://blog.csdn.net/niushuai666/article/details/7677210
http://www.cnblogs.com/wanghetao/archive/2012/04/04/2431760.html