sizeof与strlen()函数的对比总结
目录
- 1.sizeof操作符
- 1.1sizeof操作符特点
- 2.strlen( )函数
- 2.1 函数简介
- 2.2 创建字符串
- 3.sizeof 和 strlen的对比
1.sizeof操作符
在学习操作符的时候,我们学习了 sizeof , sizeof 计算变量所占内存内存空间⼤⼩的,单位是字节,如果操作数是类型的话,计算的是使⽤类型创建的变量所占内存空间的⼤⼩。
- sizeof 只关注占⽤内存空间的⼤⼩,不在乎内存中存放什么数据。
- sizeof是操作符,不是函数,函数数的调用需要括号,二sizeof的调用不需要。
int main()
{
int a = 10;
printf("%zd\n", sizeof(a));
printf("%zd\n", sizeof a);
printf("%zd\n", sizeof(int));
return 0;
}
运行结果:
1.1sizeof操作符特点
刚刚我们就已经讲到:
sizeof 只关注占⽤内存空间的⼤⼩,不在乎内存中存放什么数据。其实sizeof操作符还不会对操作对象进行计算:
int main()
{
int a = 8;
short s = 4;
printf("%zd\n", sizeof(s = a + 2));
printf("%zd\n", s);
return 0;
}
所以按照我们分析,这个程序打印出来应该是short类型的字节长度,而且不会计算a+2;我们来看看结果是否如此:
为什么呢:
这里我们简单讲一下:
我们知道C语言是编译型语言,一个程序需要经过:编译-- >链接–>test.exe -->运行;
而表达式是在运行的时候才开始计算,但 sizeof 主要是静态编译阶段的一部分,它在编译时期就能确定数据对象的存储大小,不需要运行时的信息;所以sizeof不会计算表达式;
2.strlen( )函数
2.1 函数简介
strlen 是C语⾔库函数,功能是求字符串⻓度。函数原型如下:
size_t strlen ( const char * str );
统计的是从 strlen 函数的参数 str 中这个地址开始向后, \0 之前字符串中字符的个数。strlen 函数会⼀直向后找 \0 字符,直到找到为⽌,所以可能存在越界查找。
int main()
{
const char* str1 = "abcd\0ef";
const char* str2 = "abcdaef";
printf("%zd\n", strlen(str1));
printf("%zd\n", strlen(str2));
return 0;
}
我们可以预测一下结果:
2.2 创建字符串
创建字符串的场景有很多:
int main()
{
char arr[] = "abcdef"; //a b c d e f \0
const char* str = "abcdef"; //a b c d e f \0
return 0;
}
这两种创建方法都可以用strlen函数得出其字符串长度;因为在创建的时候默认在末尾加了‘\0’
但有一种方法要注意:
char arr1[] = { 'a', 'b', 'c' };
这种创建方法并不会在末尾加‘\0’,所以用strlen函数求长度就充满了不确定性:
#include <string.h>
int main()
{
char arr[] = "abcdef"; //a b c d e f \0
const char* str = "abcdef"; //a b c d e f \0
char arr1[] = { 'a', 'b', 'c' };
printf("%zd ", strlen(arr));
printf("%zd ", strlen(str));
printf("%zd ", strlen(arr1));
return 0;
}
3.sizeof 和 strlen的对比
sizeof | strlen |
---|---|
1. sizeof是操作符 | 1. strlen是库函数,使⽤需要包含头⽂件 string.h |
2. sizeof计算操作数所占内存的⼤⼩,单位是字节 | 2. srtlen是求字符串⻓度的,统计的是 \0 之前字符的隔个数 |
3. 不关注内存中存放什么数据 | 3. 关注内存中是否有 \0 ,如果没有 \0 ,就会持续往后找,可能会越界 |