sizeof 和 strlen

1. sizeof

1.1 sizeof是一个独立的运算符,不是函数。sizeof给我们提供有关数据项目所分配的内存的大小。例如:

1
2
cout << sizeof(long) << endl;   // 输出: 4
cout << sizeof(double) << endl; // 输出:8

1.2 如果将sizeof应用于一个类型,必须要像上面所示那样使用括号。但如果对一个变量使用它,可以不用括号。

1
2
int x;
cout << sizeof x << endl;       // 输出: 4

1.3 char类型表示单个字符,只占一个字节的内存空间,所以sizeof(char)=sizeof(‘a’)=1 。另外,相关数据项目为空,所以sizeof(‘’)不为零,而是报错。但是,“”为一个C风格的字符串,末尾会被自动加上结束符‘\n’,所以有sizeof(“”)=1,sizeof(“\0”)=2。

1
2
3
4
5
6
char c = 'c';
cout << sizeof(char) << endl;   // 输出:1
cout << sizeof(c) << endl;      // 输出:1
//cout << sizeof('') << endl;   // 编译时错误:不能为空字符常量
cout << sizeof("") << endl;     // 输出:1
cout << sizeof("\0") << endl;   // 输出:2

1.4 str1是一个指针,只是指向了字符串"hello"而已。所以sizeof(str1)不是字符串占的空间也不是字符数组占的空间,而是一个字符型指针占的空间。所以sizeof(str1)=sizeof(char*)=4,在C/C++中一个指针占4个字节。*str与str[0]一样,都表示字符串中的第一个字符‘h’,所以sizeof(*str1)=1。*(str1+1)表示第二个字符,依次类推。

1
2
3
4
const char* str1 = "hello";
cout << sizeof(str1) << endl;   // 输出:4
cout << sizeof(char*) << endl;  // 输出:4
cout << sizeof(*str1) << endl;  // 输出:1

1.5 str2是一个字符型数组。C/C++规定,对于一个数组,返回这个数组占的总空间,所以sizeof(str2)取得的是字符串"hello" 占的总空间。"hello"中,共有h e l l o \0六个字符,所以str2数组的长度是6,所以sizeof(str2)=6*sizeof(char)=6 。

1
2
char str2[]="hello";
cout << sizeof(str2) << endl;   // 输出:6

1.6 str3已经定义成了长度是8的数组,所以sizeof(str3)=8*sizeof(char)=8 。

1
2
char str3[8]={'h',};
cout << sizeof(str3) << endl;   // 输出:8

1.7 如果给出的数据项目不是字符型数组,而是一种自定义类型对像数组,那么sizeof(str3)=8*sizeof(对像类型或对像)。如:

1
2
3
4
5
6
7
8
class A
{
    int x;
    double d;
};
A a[10];
cout << sizeof(A) << endl;      // 输出:16,此处有内存补齐,所以不是12
cout << sizeof(a) << endl;      // 输出:160

1.8 大部分编译程序在编译的时候就把sizeof计算过了,这就是sizeof(x)可以用来定义数组长度的原因。下面数组a2的长度是根据a1的长度来定的。

1
2
3
4
int a1[10];
cout << sizeof(a1)/sizeof(int) << endl;     // 输出:10
int a2[sizeof(a1)/sizeof(int)];
cout << sizeof(a2)/sizeof(int) << endl;     // 输出:10

1.9 sizeof 操作符不能返回动态地被分派了的数组或外部的数组的尺寸,特别是当sizeof应用于虚参形式的数组时,得到的结果是4(指针大小) 。应牢记住数组在作为参数传递时,永远都是传递数组的地址。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#define MAXSIZE 100
 
// 此处等同于 void PrintSize(char* str)
void PrintSize(char str[MAXSIZE])
{
    cout << sizeof(str) << endl;        // 输出:4
}
 
int main()
{
    char str1[MAXSIZE];
    cout << sizeof(str1) << endl;       // 输出:100
    PrintSize(str1);
}

2.0 sizeof还可以应用于函数,注意函数fun只声明未定义:

1
2
3
4
5
6
7
double fun();
 
int main()
{
    cout << sizeof(fun()) << endl;      // 输出:8
    //cout << sizeof(fun) << endl;      // 编译时出错:非法的sizeof操作数
}

2.1 sizeof操作符不能用于函数类型,不完全类型或位字段。不完全类型指具有未知存储大小的数据类型,如未知存储大小的数组类型、未知内容的结构或联合类型、void类型等

1
2
//cout << sizeof(void) << endl;     // 编译时出错:非法的sizeof操作数
cout << sizeof(void*) << endl;      // 输出:4,就是指针的存储空间

总之,对于指针,sizeof操作符返回这个指针占的空间,一般是4个字节;而对于一个数组,sizeof返回这个数组所有元素占的总空间。char*与char[]容易混淆,一定要分清。sizeof可应用于任何内置类型和自定义类型。

2. strlen

2.1 strlen是函数,它不区分是数组还是指针,就读到\0为止返回长度。而且strlen是不把/0计入字符串的长度的。使用时需要包函头文件string.h。

1
2
3
4
5
6
7
char str4[] = "hello";
cout << strlen(str4) << endl;   // 输出: 5
const char *str5 = "hello";
cout << strlen(str5) << endl;   // 输出:5
 
cout << strlen("") << endl;     // 输出:0
cout << strlen("\0") << endl;   // 输出:0

2.2 strlen只能用于C类型字符串,注意必须是字符串且以‘\0’结尾,用于其它任何类型都是错误的。

1
2
3
4
5
6
7
8
9
10
11
12
13
//cout << strlen(int) << endl;  // 出错:不能用于类型
//cout << strlen('') << endl;   // 出错:不能用于字符
//cout << strlen('a') << endl;  // 出错:不能用于字符
char str6[5] = {'h', 'e', 'l', 'l', 'o'};
//cout << strlen(str6) << endl; // 运行时出错:str6不是一个"C风格字符串",即不是以'\0'
                                    // 结尾的字符串,此处输出一个不确定值,本例为19
class B
{
    int x;
    double d;
};
B b[10];
//cout << strlen(b) << endl;    // 出错:一句话,只能用于字符串,还必须是“C风格的”

2.3 strlen的结果要在运行的时候才能计算出来。

posted @ 2015-10-29 19:27  吴下阿蒙zlf  阅读(174)  评论(0编辑  收藏  举报