练习-sizeof()和strlen()

目录

  • 前言
  • 解题技巧
  • 一、sizeof()练习题
    • 1.1 整型数组
      • 1.1.1 一维整型数组
      • 1.1.2 二维整型数组
    • 1.2 字符数组
    • 1.3 字符指针
  • 二、strlen()练习题
    • 2.1 字符数组初始化时不包含\0
    • 2.2 字符数组初始化包含\0
    • 2.3 字符指针指向字符串常量
  • 总结


前言

最近有点疲倦,啊啊啊,麻了…
今天写点轻松的东西,本篇文章记录关于sizeof()和strlen()的练习题。


解题技巧

(1)关于sizeof()使用的思考方向:

  1. 计算数据类型大小,例如 sizeof(int)
  2. 计算地址的大小,例如 sizeof(&pa),pa为变量
  3. 计算整个数组的大小,例如 sizeof(arr) arr为数组名

(2)关于strlen()使用的思考方向

首先,strlen()计算的是字符串的长度,遇到\0才停止计算,计算结果不包含\0,参数类型为 const char*

  1. 字符数组在初始化时不包含\0,则计算结果为随机值
  2. 字符数组在初始化时包含\0,则计算结果为字符的个数,不包含\0
  3. 字符串常量自动包含\0

一、sizeof()练习题

1.1 整型数组

1.1.1 一维整型数组

int main()
{int arr[] = { 1,2,3,4 };printf("sizeof(arr)       = %zu\n", sizeof(arr));//sizeof(数组名),计算的是整个数组的大小  4*4 = 16printf("sizeof(arr+0)     = %zu\n", sizeof(arr + 0));//计算的是首元素地址的大小printf("sizeof(*arr)      = %zu\n", sizeof(*arr));//sizeof(*arr) == sizeof(arr[0]) 计算首元素的大小printf("sizeof(arr+1)     = %zu\n", sizeof(arr + 1));//sizeof(arr+1) == sizeof(&arr[1]) 计算第二个元素地址的大小printf("sizeof(arr[1])    = %zu\n", sizeof(arr[1]));//计算第二个元素的大小printf("sizeof(&arr)      = %zu\n", sizeof(&arr));//计算整个数组地址的大小printf("sizeof(*&arr)     = %zu\n", sizeof(*&arr));//sizeof(*&arr) == sizeof(arr) 计算整个数组的大小printf("sizeof(&arr+1)    = %zu\n", sizeof(&arr + 1));//sizeof(&arr+1) 计算跳过整个数组后的地址的大小(本质计算地址大小)printf("sizeof(&arr[0])   = %zu\n", sizeof(&arr[0]));//计算首元素地址的大小printf("sizeof(&arr[0]+1) = %zu\n", sizeof(&arr[0] + 1));//sizeof(&arr[0]+1) == sizeof(&arr[1]) 计算的是第二个元素地址的大小return 0;
}

32位机器输出结果
在这里插入图片描述
64位机器输出结果
在这里插入图片描述


1.1.2 二维整型数组

int main()
{int arr[3][4] = { 0 };printf("sizeof(arr)          = %zu\n", sizeof(arr));//计算二维数组的大小  3*4*sizeof(int) = 3*4*4 = 48printf("sizeof(arr[0][0])    = %zu\n", sizeof(arr[0][0]));//计算元素类型的大小 sizeof(0) = sizeof(int) = 4printf("sizeof(arr[0])       = %zu\n", sizeof(arr[0]));//arr[0]表示的是第一行的数组名,计算的是第一行的大小  4*sizeof(int) = 4*4 = 16printf("sizeof(arr[0]+1)     = %zu\n", sizeof(arr[0] + 1));//arr[0] 表示第一行的数组名, arr[0]+1 表示的是第一行第二个元素的地址  &arr[0][1]//4/8printf("sizeof(*(arr[0]+1))  = %zu\n", sizeof(*(arr[0] + 1)));// arr[0]+1 -> &arr[0][1]     *(arr[0]+1) = 0   计算元素类型的大小 4printf("sizeof(arr+1)        = %zu\n", sizeof(arr + 1));//arr+1,此时 arr表示首元素地址,第一行的地址, arr+1表示第二行的地址//计算地址大小  4/8printf("sizeof(*(arr+1))     = %zu\n", sizeof(*(arr + 1)));//对第二行的地址进行解引用,计算的是第二行数组的大小  16printf("sizeof(&arr[0]+1)    = %zu\n", sizeof(&arr[0] + 1));//&arr[0] 取出的是整个一维数组的地址, &arr[0]+1表示的是第二行的地址//计算地址的大小 4/8printf("sizeof(*(&arr[0]+1)) = %zu\n", sizeof(*(&arr[0] + 1)));//&arr[0] +1 表示第二行的地址  对第二行进行解引用,计算的是一维数组的大小 //16printf("sizeof(*arr)         = %zu\n", sizeof(*arr));//arr表示首元素地址,即第一行的地址 对一行地址解引用//计算一维数组的大小  16printf("sizeof(arr[3])       = %zu\n", sizeof(arr[3]));//arr[3] -> arr[0] 计算一维数组的大小//16return 0;
}

32位机器输出结果
在这里插入图片描述
64位机器输出结果
在这里插入图片描述


1.2 字符数组

int main()
{char str[] = { 'a','b','c','d','e','f' };printf("sizeof(str)       = %zu\n", sizeof(str));//计算整个数组大小printf("sizeof(str+0)     = %zu\n", sizeof(str + 0));//计算首元素地址大小printf("sizeof(*str)      = %zu\n", sizeof(*str));//*str == str[0] == 'a'  计算元素的类型大小 sizeof(char)printf("sizeof(str[1])    = %zu\n", sizeof(str[1]));//计算元素的类型大小 sizeof(char)printf("sizeof(&str)      = %zu\n", sizeof(&str));//&str整个数组的地址 计算的是地址的大小printf("sizeof(&str+1)	  = %zu\n", sizeof(&str + 1));//计算的是地址大小printf("sizeof(&str[0]+1) = %zu\n", sizeof(&str[0] + 1));//计算第二个元素的地址大小return 0;
}

32位机器输出结果
在这里插入图片描述
64位机器输出结果
在这里插入图片描述


1.3 字符指针

int main()
{const char* p = "abcdef";printf("sizeof(p)       = %zu\n", sizeof(p));//计算地址大小printf("sizeof(p+1)     = %zu\n", sizeof(p + 1));//计算地址大小printf("sizeof(*p)      = %zu\n", sizeof(*p));//计算元素类型大小printf("sizeof(p[0])    = %zu\n", sizeof(p[0]));//计算元素类型大小printf("sizeof(&p)      = %zu\n", sizeof(&p));//计算地址大小printf("sizeof(&p+1)    = %zu\n", sizeof(&p + 1));//计算地址大小printf("sizeof(&p[0]+1) = %zu\n", sizeof(&p[0] + 1));//计算地址大小return 0;
}

32位机器输出结果
在这里插入图片描述
64位机器输出结果
在这里插入图片描述


二、strlen()练习题

2.1 字符数组初始化时不包含\0

#include<string.h>
int main()
{char str[] = { 'a','b','c','d','e','f' };printf("strlen(str)    = %zu\n", strlen(str));//随机值 值>=6printf("strlen(str+0)  = %zu\n", strlen(str + 0));//随机值 值>=6//printf("strlen(*str)   = %zu\n", strlen(*str));//程序错误  *str == 'a' == 97 //printf("strlen(str[1]) = %zu\n", strlen(str[1]));//程序错误  str[1] == 'b' == 98printf("strlen(&str)   = %zu\n", strlen(&str));//&str的类型为 char(*)[6] 与strlen()的参数类型不相同,会有警告//随机值 值>=6  &str整个数组的地址,但是 &str的值和str的值相同,但类型不相同printf("strlen(&str+1) = %zu\n", strlen(&str + 1));//随机值-6return 0;
}

输出运行结果
在这里插入图片描述


2.2 字符数组初始化包含\0

int main()
{char str[] = "abcdef";printf("strlen(str)    = %zu\n", strlen(str));//值为6printf("strlen(str+0)  = %zu\n", strlen(str + 0));//值为6//printf("strlen(*str)   = %zu\n", strlen(*str));//程序错误  *str == 'a' == 97 //printf("strlen(str[1]) = %zu\n", strlen(str[1]));//程序错误  str[1] == 'b' == 98printf("strlen(&str)   = %zu\n", strlen(&str));//&str的类型为 char(*)[6] 与strlen()的参数类型不相同,会有警告//值为6  &str整个数组的地址,但是 &str的值和str的值相同,但类型不相同printf("strlen(&str+1) = %zu\n", strlen(&str + 1));//随机值return 0;
}

输出运行结果
在这里插入图片描述


2.3 字符指针指向字符串常量

int main()
{const char* p = "abcdef";printf("strlen(p)       = %zu\n", strlen(p));//值为6printf("strlen(p+1)     = %zu\n", strlen(p + 1));//值为5//printf("strlen(*p)      = %zu\n", strlen(*p));//printf("strlen(p[0])    = %zu\n", strlen(p[0]));//程序错误printf("strlen(&p)      = %zu\n", strlen(&p));//随机值printf("strlen(&p+1)    = %zu\n", strlen(&p + 1));//随机值printf("strlen(&p[0]+1) = %zu\n", strlen(&p[0] + 1));//值为5return 0;
}

输出运行结果
在这里插入图片描述


总结

sizeof()计算内存空间大小:
sizeof(单独数组名):计算数组大小;
sizeof(地址) :计算地址大小;
sizeof(类型):计算类型大小。
strlen()计算字符串长度

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/616072.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电容的基础知识

一、电容单位 电容亦称作“电容量”&#xff0c;是指在给定电位差下的电荷储藏量&#xff0c;记为C&#xff0c;国际单位是法拉&#xff08;F&#xff09;。在国际单位制里&#xff0c;电容的单位是法拉&#xff0c;简称法&#xff0c;符号是F&#xff0c;由于法拉这个单位太大…

vue3项目部署到服务器,刚打开没事,一刷新页面就404

vue3项目部署到服务器&#xff0c;刚打开没事&#xff0c;一刷新页面就404 vue3项目&#xff0c;在本地调试时各方面都没毛病&#xff0c;刷新也没毛病&#xff0c;但是&#xff0c;扔到服务器上&#xff0c;第一次打开是正常的&#xff0c;再刷新下就404了&#xff0c;不知道什…

GLES学习笔记---立方体贴图(一张图)

一、首先看一张效果图 立方体贴图 二、纹理坐标划分 如上图是一张2D纹理&#xff0c;我们需要将这个2D纹理贴到立方体上&#xff0c;立方体有6个面&#xff0c;所以上面的2D图分成了6个面&#xff0c;共有14个纹理坐标 三、立方体 上边的立方体一共8个顶点坐标&#xff0c;范围…

地图多点自动缩放,居中,思路和手写

效果如下 多个标记点顺次标记连接起来zoom缩放到合适等级&#xff0c;刚好能放下那么多点视野刚好在正中间 zoom 实现思路 获取多点的最大经纬度点和最小经纬度点&#xff08;这两个点相距离最远&#xff09;计算2个这两点之间的距离地图是有比例尺的&#xff0c;根据比例尺…

1.傅里叶处理图片原理和代码实现

在这里首先声明&#xff0c;本文纯粹看了别的博主的文章&#xff0c;觉得博主写的原理清晰明了&#xff0c;容易理解&#xff0c;很详细&#xff0c;在这里写一遍是作为笔记&#xff0c;方便以后再翻看时容易查找。大家可以参考下面这个博文&#xff1a; 图像的傅里叶变换_图像…

SAP OData(二)Association

Entity之间用Association来表示关联关系&#xff0c;可以同CDS view中的Association一起理解。 我们在上次已经建好实体Item的基础上&#xff0c;再建一个Header&#xff0c;其方法的重写也参考Item即可&#xff0c;然后开始本篇的探索。 一&#xff0c;构建Association 1.1…

脑科学与人工神经网络ANN的发展历程与最新研究

本文深入研究了ANN的基本概念、发展背景、应用场景以及与人脑神经网络的关系。 关注TechLead&#xff0c;分享AI全维度知识。作者拥有10年互联网服务架构、AI产品研发经验、团队管理经验&#xff0c;同济本复旦硕&#xff0c;复旦机器人智能实验室成员&#xff0c;阿里云认证的…

抽奖机制模型及算法

抽奖机制 连抽保底概率模型不中概率加大模型&#xff08;抽卡保底&#xff09; 抽奖概率为n%&#xff0c;在达到某次次数后&#xff0c;每次概率比上次高m%&#xff0c;直至达到保底次数&#xff08;概率累加和为100%&#xff09;&#xff0c;当抽到极品道具时候&#xff0c;…

网络传输(TCP)

前言 我们tcpdump抓包时会看到除报文数据外&#xff0c;前面还有一段其他的数据&#xff0c;这段数据分为两部分&#xff0c;ip包头&#xff08;一般20字节&#xff09;和tcp包头&#xff08;一般20字节&#xff09;&#xff0c;一般这两个头长度和为40&#xff0c;我们直接跳…

SQL-DQL-基础查询

&#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&#xff1a;重拾MySQL &#x1f379;文章作者技术和水平很有限&#xff0c;如果文中出现错误&am…

制造业管理者必备技能:掌握6S管理!

当今竞争激烈的制造业领域&#xff0c;为了提高效率、优化流程&#xff0c;并实现持续创新&#xff0c;制造业管理者需要掌握一种全面、系统的管理方法——6S管理。6S管理是源自于日本的精益管理方法&#xff0c;通过整理、整顿、清扫、标准化、维持和安全这六个步骤&#xff0…

基于SkyEye仿真6678处理器:实现国产操作系统ReWorks仿真运行

信号处理的数据量以及实时性的要求随着嵌入式技术的发展不断提高&#xff0c;众多厂商和研究所选择多核DSP处理器芯片去替代原有的单核DSP&#xff0c;并运行嵌入式操作系统来保证信号处理的实时性以及精确性。然而受到硬件资源或者项目实施周期限制&#xff0c;软件工程师调试…

Jmerer之FTP测试

1、文件上传下载测试&#xff0c;可以使用sample:FTP请求&#xff0c;当然也可以使用HTTP Request采样器中的File Upload向服务器上传文件 2、本章重点介绍FTP请求进行文件的上传下载测试&#xff0c;添加 FTP请求&#xff0c;界面主要配置如下&#xff1a; Server Name or I…

Linux 软连接ln -s

什么是文件软链接&#xff1f; Linux 的“软连接”与windos 的"快捷方式"相似。文件软链接&#xff08;Symbolic Link 或 SymLink&#xff09;是一种特殊的文件类型&#xff0c;它实际上是一个指向另一个文件或目录的引用。创建软链接时&#xff0c;系统会建立一个新…

访问学者申请需要注意什么?

访问学者申请是一项复杂而重要的过程&#xff0c;需要申请人在准备材料和过程中注意一些关键事项&#xff0c;以确保顺利完成申请并提高成功率。以下是知识人网小编的一些建议&#xff0c;希望对你的访问学者申请有所帮助。 1. 详细了解目标学术机构&#xff1a; 在申请访问学…

SQL性能分析-整理

昨日对MySQL的索引整理了一份小文档&#xff0c;对结构/分类/语法等做了一个小总结&#xff0c;具体文章可点击&#xff1a;MySQL-索引回顾&#xff0c;索引知识固然很重要&#xff0c;但引入运用到实际工作中更重要。 参考之前的文章&#xff1a;SQL优化总结以及参考百度/CSDN…

深入探讨:开发连锁餐饮APP的关键技术要点

时下&#xff0c;开发一款功能强大、用户友好的连锁餐饮APP成为许多餐饮企业的当务之急。在本文中&#xff0c;我们将深入探讨开发连锁餐饮APP的关键技术要点&#xff0c;涵盖了前端、后端以及数据库等方面。 一、前端开发 前端是用户与APP交互的入口&#xff0c;因此设计良好…

比尔盖茨:如果只能解决一个问题,我的答案总是营养不良

谷禾健康 当地时间12月19日&#xff0c;微软联合创始人、亿万富翁比尔盖茨发布了对来年的年度预测&#xff0c;称 2024 年将是一个“转折点”。 在这封长达 10 页的信中他展示了对人工智能领域的更多创新、婴儿营养不良问题的突破、气候变化谈判的进展等多方面的期待。 人工智能…

【iOS】数据持久化(四)之FMDB

正如我们前面所看到的&#xff0c;原生SQLite API在使用时还是比较麻烦的&#xff0c;于是&#xff0c;开源社区就出现了一系列将SQLite API进行封装的库&#xff0c;其中FMDB的被大多数人所使用 FMDB和SQLite相比较&#xff0c;SQLite比较原始&#xff0c;操作比较复杂&#…

如何制作能够提高产品的市场认知度的产品说明书模板?

在当今竞争激烈的市场环境中&#xff0c;产品的市场认知度对于企业的成功至关重要。一个深入人心的产品形象&#xff0c;不仅能提高销售额&#xff0c;还能塑造品牌形象&#xff0c;增强消费者忠诚度。那么如何能有效地提高产品的市场认知度呢&#xff1f;接下来就说一下&#…