先来看一段代码
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而b=20;
strlen(char*)函数求的是字符串的实际长度,它求得方法是从开始到遇到第一个'\0',如果你只定义没有给它赋初值,这个结果是不定的,它会从aa首地址一直找下去,直到遇到'\0'停止。.
sizeof操作符以字节形式给出了其操作数的存储大小。
具体看代码:
把存储单元的实际地址与其所在段的段地址之间的距离称为段内偏移,也称为“有效地址或偏移量”。
例如一个存储器的大小是1KB,可以把它分为4段,第一段的地址范围就是0—255,第二段的地址范围就是256-511,以此类推。这些段内的偏移地址就是在0-255的范围内的。
额,以下代码是拷贝别人的,但觉得很好,就跟大家一起分享以下了。
struct MyStruct
{
char ch; // 偏移量为0,满足对齐方式,ch占用1个字节;
double doub; //下一个可用的地址的偏移量为1,不是sizeof(double)=8
//的倍数,需要补足7个字节才能使偏移量变为8(满足对齐
//方式),因此VC自动填充7个字节,doub存放在偏移量为8
//的地址上,它占用8个字节。
int i; //下一个可用的地址的偏移量为16,是sizeof(int)=4的倍
//数,满足int的对齐方式,所以不需要VC自动填充,i存
//放在偏移量为16的地址上,它占用4个字节。
};
//所有成员变量都分配了空间,空间总的大小为1+7+8+4=20,
sizeof是操作符(关键字),strlen是函数。
sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以''\0''结尾的。