size0f()与strlen()的区别

先来看一段代码

char str[20]="0123456789"; 

int a=strlen(str); //a=10; 

int b=sizeof(str); //b=20; 

strlen(char*)函数求的是字符串的实际长度,它求得方法是从开始到遇到第一个'\0',如果你只定义没有给它赋初值,这个结果是不定的,它会从aa首地址一直找下去,直到遇到'\0'停止。.

sizeof操作符以字节形式给出了其操作数的存储大小

具体看代码:

把存储单元的实际地址与其所在段的段地址之间的距离称为段内偏移,也称为“有效地址或偏移量”。

例如一个存储器的大小是1KB,可以把它分为4段,第一段的地址范围就是0255,第二段的地址范围就是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''结尾的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值