练习-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;不知道什…

视频号小店入口在哪?需要什么资质?实操详解!

我是电商珠珠 视频号小店于22年7月产生&#xff0c;距今才发展了一年时间。今年正是它风口期正盛的时候&#xff0c;有很多想要入驻的新手还不知道它在哪&#xff0c;都需要什么资质。 接下来我来给大家详细的讲一下。 视频号小店入口 1、手机端 打开vx搜索“视频号开店”…

第二十章 常见的设计模式

文章目录 一、设计模式二、单例模式三、工厂模式四、抽象工厂模式五、适配器模式六、观察者模式七、代理模式八、策略模式九、MVC模式十、组合模式 一、设计模式 什么是设计模式 设计模式是一种固定的解决问题的方式是一套经过代码设计经验总结优化之后的固定的方式是软件工程…

vue2使用富文本wangeditor

安装 npm i wangeditor --save引用 import E from wangeditor;使用 // 富文本初始化initEditor() {this.isEdit true;this.$nextTick(() > {this.editor new E(this.$refs.editorElem); //绑定节点this.editor.config.height 550; //默认高度为 300&#xff0c;设置高度…

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

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

图像处理中常用的距离

说明 在图像处理中&#xff0c;常用的距离度量用于衡量两个向量或特征之间的差异或相似性。以下是一些常用的距离度量及其使用说明和应用场景&#xff1a; 欧氏距离&#xff08;Euclidean Distance&#xff09;&#xff1a;欧氏距离是最常用的距离度量&#xff0c;用于衡量两个…

Docker-Compose编排Nginx1.25.1+PHP7.4.33+Redis7.0.11环境

实践说明&#xff1a;基于RHEL7(CentOS7.9)部署docker环境(23.0.1、24.0.2)&#xff0c;编排也可应用于RHEL7-9(如AlmaLinux9.1)&#xff0c;但因为docker的特性&#xff0c;适用场景是不限于此的。 文档形成时期&#xff1a;2017-2023年 因系统或软件版本不同&#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;我们直接跳…

C语言实现单向链表

1.线性表 线性表可以分成两种 一种就是顺序表 也就是我们所熟知的数组 一种是今天的主角–链表 他们两者的区别在于 前者是顺序储存元素的 即数组元素的地址值是连续的 后者则是链式储存的 节点的地址值不一定连续 2.单向链表 链表中的节点是由两部分组成的 一部分是数据域 …

SQL-DQL-基础查询

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

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

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

监督学习 - 决策树回归(Decision Tree Regression)

什么是机器学习 **决策树回归&#xff08;Decision Tree Regression&#xff09;**是一种机器学习算法&#xff0c;用于解决回归问题。与分类问题不同&#xff0c;回归问题的目标是预测连续型变量的值&#xff0c;而不是离散的类别。决策树回归通过构建一棵决策树来进行预测。…

力扣(leetcode)第599题两个列表的最小索引总和(Python)

599.两个列表的最小索引总和 题目链接&#xff1a;599.两个列表的最小索引总和 假设 Andy 和 Doris 想在晚餐时选择一家餐厅&#xff0c;并且他们都有一个表示最喜爱餐厅的列表&#xff0c;每个餐厅的名字用字符串表示。 你需要帮助他们用最少的索引和找出他们共同喜爱的餐厅…

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

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