例子:
char* ss = "0123456789";
sizeof(ss) 结果 4 //ss是指向字符串常量的字符指针
sizeof(*ss) 结果 1 //*ss是第一个字符
char ss[] = "0123456789";
sizeof(ss) 结果 11 //ss是数组,计算到\0位置,因此是10+1
sizeof(*ss) 结果 1 //*ss是第一个字符
char ss[100] = "0123456789";
sizeof(ss) 结果是100 //ss表示在内存中的大小 100×1
strlen(ss) 结果是10 //strlen是个函数内部实现是用一个循环计算到\0为止之前
int ss[100] = "0123456789";
sizeof(ss) 结果 400 //ss表示再内存中的大小 100×4
strlen(ss) 错误 //strlen的参数只能是char* 且必须是以''\0''结尾的
char q[]="abc";
char p[]="a\n";
sizeof(q),sizeof(p),strlen(q),strlen(p);
结果是 4 3 3 2
class X
{
int i;
int j;
char k;
};
X x;
cout<<sizeof(X)<<endl; 结果 12 //内存补齐
cout<<sizeof(x)<<endl; 结果 12 同上
char c;
sizeof c;//变量名可以不加括弧
char szPath[MAX_PATH]
如果在函数内这样定义,那么sizeof(szPath)将会是MAX_PATH,但是将szPath作为虚参声明时(void fun(char szPath[MAX_PATH])),sizeof(szPath)却会是4(指针大小)
1.sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。字节大小。
2.sizeof是算符,strlen是函数。
3.sizeof可以用类型和函数做参数,strlen只能用char*做参数,且必须是以''\0''结尾的。
short f();
printf("%d\n", sizeof(f()));
输出的结果是sizeof(short),即2。
4.数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,如:
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);
}
5.计算结构变量的大小就必须讨论数据对齐问题。为了CPU存取的速度最快(这同CPU取数操作有关),C++在处理数据时经常把结构变量中的成员的大小按照4或8的倍数计算,这就叫数据对齐(data alignment)。这样做
可能会浪费一些内存,但理论上速度快了。
char* ss = "0123456789";
sizeof(ss) 结果 4 //ss是指向字符串常量的字符指针
sizeof(*ss) 结果 1 //*ss是第一个字符
char ss[] = "0123456789";
sizeof(ss) 结果 11 //ss是数组,计算到\0位置,因此是10+1
sizeof(*ss) 结果 1 //*ss是第一个字符
char ss[100] = "0123456789";
sizeof(ss) 结果是100 //ss表示在内存中的大小 100×1
strlen(ss) 结果是10 //strlen是个函数内部实现是用一个循环计算到\0为止之前
int ss[100] = "0123456789";
sizeof(ss) 结果 400 //ss表示再内存中的大小 100×4
strlen(ss) 错误 //strlen的参数只能是char* 且必须是以''\0''结尾的
char q[]="abc";
char p[]="a\n";
sizeof(q),sizeof(p),strlen(q),strlen(p);
结果是 4 3 3 2
class X
{
int i;
int j;
char k;
};
X x;
cout<<sizeof(X)<<endl; 结果 12 //内存补齐
cout<<sizeof(x)<<endl; 结果 12 同上
char c;
sizeof c;//变量名可以不加括弧
char szPath[MAX_PATH]
如果在函数内这样定义,那么sizeof(szPath)将会是MAX_PATH,但是将szPath作为虚参声明时(void fun(char szPath[MAX_PATH])),sizeof(szPath)却会是4(指针大小)
1.sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。字节大小。
2.sizeof是算符,strlen是函数。
3.sizeof可以用类型和函数做参数,strlen只能用char*做参数,且必须是以''\0''结尾的。
short f();
printf("%d\n", sizeof(f()));
输出的结果是sizeof(short),即2。
4.数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,如:
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);
}
5.计算结构变量的大小就必须讨论数据对齐问题。为了CPU存取的速度最快(这同CPU取数操作有关),C++在处理数据时经常把结构变量中的成员的大小按照4或8的倍数计算,这就叫数据对齐(data alignment)。这样做
可能会浪费一些内存,但理论上速度快了。