C语言中sizeof和strlen的区别【详解】

简介: sizeof和strlen的区别

一、sizeof的用法和说明

   运算符sizeof用于计算数据类型所占字节数,就是计算该数据所占空间大小。单位是字节,叫求字节数运算符,它是一个关键字,一个单目运算符,优先级高于双目运算符,其一般格式如下:

(1)sizeof(表达式)或 sizeof 表达式

(2)sizeof(数据类型名)

不同数据类型字节数示例。

#include<stdio.h>
int main()
{
  printf("int类型占%d个字节\n", sizeof(int));
  printf("float类型占%d个字节\n", sizeof(float));
  printf("double类型占%d字节\n", sizeof(double));
  printf("char类型占%d字节\n", sizeof(char));
  printf("short int类型占%d字节\n", sizeof(short int));
  return 0;
}

image.gif

运行结果

image.png

image.gif由此可以看出各个数据类型所占空间的不同。

求字节数运算符示例。

#include<stdio.h>
int main()
{
  int a, b, d;
  char c[] = "China";
  a = sizeof(2 + 3.0);
  b = sizeof 3 + 5.0;
  d = sizeof(c);
  printf("%d %d %d %d", a, b, d,sizeof("China"));
  return 0;
}

image.gif

运行结果

image.png

   由以上代码可知,a求的是double数据类型的字节数,b求的是int类型数据类型,之后加5.0,输出时转换为整型数,d求的是字符串所占字节数,在数组上的应用,加上字符串结束符‘\0’,总共6个字节,最后一个也是在字符串的求字节运算,也是加上‘\0’,总共6个字节。可以总结出sizeof的字节数数是固定的,计算缓冲区的固定字节数。

二、strlen的用法和说明

   strlen是一个库函数,在使用它是要加头文件 #include<string.h> ,主要是用来计算字符串长度的函数,但是不包含‘\0’,只会计算‘\0’前面的长度,遇到'\0'就会结束,不管后面还有多少数据,函数strlen()的调用格式为:

strlen(字符串)

strlen()函数应用示例和sizeof()函数的对比区别。

#include<stdio.h>
#include<string.h>
int main()
{
  char c1[] = "123\0 456";
  printf("\t%d  %d\n", strlen(c1), sizeof(c1));
  return 0;
}

image.gif

运行结果

image.png

由此代码可得strlen()函数遇‘\0’结束,其值为3,sizeof()函数计算了这个字符串所占的字节数并且在加上了字符串结束符‘\0’的字节数,所以值为9。

目录
相关文章
|
1月前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别
pymalloc 和系统的 malloc 有什么区别
|
19天前
|
C语言
【C语言】sizeof 关键字详解
`sizeof` 关键字在C语言中用于计算数据类型或变量在内存中占用的字节数。它是一个编译时操作符,对性能没有影响。`sizeof` 可以用于基本数据类型、数组、结构体、指针等,了解和正确使用 `sizeof` 对于内存管理和调试程序非常重要。
46 2
|
1月前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别?
pymalloc 和系统的 malloc 有什么区别?
|
2月前
|
存储 C语言
C语言:普通局部变量、普通全局变量、静态局部变量、静态全局变量的区别
C语言中,普通局部变量在函数内部定义,作用域仅限于该函数;普通全局变量在所有函数外部定义,作用域为整个文件;静态局部变量在函数内部定义但生命周期为整个程序运行期;静态全局变量在所有函数外部定义,但仅在定义它的文件内可见。
109 10
|
2月前
|
存储 C语言
C语言:结构体与共用体的区别
C语言中,结构体(struct)和共用体(union)都用于组合不同类型的数据,但使用方式不同。结构体为每个成员分配独立的内存空间,而共用体的所有成员共享同一段内存,节省空间但需谨慎使用。
|
2月前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
2月前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
2月前
|
存储 编译器 C语言
C语言:数组名作为类型、作为地址、对数组名取地址的区别
在C语言中,数组名可以作为类型、地址和取地址使用。数组名本身代表数组的首地址,作为地址时可以直接使用;作为类型时,用于声明指针或函数参数;取地址时,使用取地址符 (&),得到的是整个数组的地址,类型为指向该类型的指针。
|
2月前
|
存储 缓存 C语言
C语言:链表和数组有什么区别
C语言中,链表和数组是两种常用的数据结构。数组是一种线性结构,元素在内存中连续存储,通过下标访问,适合随机访问且大小固定的情况。链表由一系列不连续的节点组成,每个节点存储数据和指向下一个节点的指针,适用于频繁插入和删除操作的场景,链表的大小可以动态变化。
|
2月前
|
编译器 C语言
C语言:typedef 和 define 有什么区别
在C语言中,`typedef`和`#define`都是用来创建标识符以简化复杂数据类型或常量的使用,但它们之间存在本质的区别。`typedef`用于定义新的数据类型别名,它保留了数据类型的特性但不分配内存。而`#define`是预处理器指令,用于定义宏替换,既可用于定义常量,也可用于简单的文本替换,但在编译前进行,过度使用可能导致代码可读性下降。正确选择使用`typedef`或`#define`可以提高代码质量和可维护性。