strlen和sizeof函数区别(深入理解)


1.函数类型

#include <string.h>

size_t strlen(const char *s);

size_t sizeof()

2.本质区别

本质上,strlen是函数,而sizeof是算符。strlen需要进行一次函数调用,而对于sizeof而言,因为缓冲区已经用已知字符串进行了初始 化,起长度是固定的,所以sizeof在编译时计算缓冲区的长度。sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。

3.引申区别

1). strlen计算不包含终止null字节的字符串长度,而sizeof则计算包括终止null字节的缓冲区长度。

2). strlen只能用char*做参数,且必须是以'/0'结尾的。sizeof可以用类型做参数,还可以用函数做参数。数组传递给strlen就退化为指针了,传递给sizeof的参数不退化。

3). 当适用了于一个结构类型时或变量,sizeof返回实际的大小;当适用一静态地空间数组,sizeof 归还全部数组的尺寸。sizeof 操作符不能返回动态地被分派了的数组或外部的数组的尺寸

4). 数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,如:
fun(char []) 都等价于fun(char *)

在C/C++里传递数组永远都是传递指向数组首元素的指针,编译器不知道数组的大小如果想在函数内知道数组的大小,需要这样做:

fun(const char *s, int len)

{

char* buf [len+1];

memcpy(buf, s, len);

}

5). Sizeof操作符不能用于函数类型、不完全类型或位字段。不完全类型是指具有未知存储大小的数据数据类型,如未知存储大小的数组类型,void类型等。

4.sizeof另解

程序存储分布有三个区域:栈、静态和动态。所有能够从代码直接操作的对象,包括任何类型的变量、指针,都是在栈上的;动态和静态存储区是靠栈上的指针间接操作的。sizeof 操作符,计算的是对象在栈上的投影体积;除了栈上的char数组这一个特殊情况之外。。。

sizeof计算的都是类型的长度。如果是对象,则转换成类型,再计算类型的长度。

在32位系统中。指针类型是32位,4个字节。所以对任何指针用sizeof结果都是4;

1). 数组用sizeof = 数组的步长(类型的长度)*数组的长度。

2). 复合结构sizeof= 各个数据成员的类型长度*声明的个数之和。(要考虑到字节对齐)

typedef struct student

{

int data;

static int number;

}node1;

typedef struct teacher

{

int data;

char name;

}node2;

sizeof(node1)=4个字节。//静态变量是放在全局数据区,sizeof计算栈分配的大小,不会计算静态变量的。

sizeof(node2)=8个字节。//字节对齐

3). 引用用 sizeof 。 如果引用的是对象,则先转化成引用的对象类型。如果是复合类型。则用2。否则直接计算。

优质内容筛选与推荐>>
1、Java版本不一致的问题
2、js 中{},[]中括号,大括号使用详解
3、lslpp 总结
4、sql分页
5、生成器


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号