指针、数组、sizeof、strlen相关知识与练习题目
目录
前提回顾🔍:
关于一维数组🤮:
关于二维数组😀:
sizeof与strlen🐕:
sizeof🏀:
strlen🐓:
相关练习📚:
一维数组与sizeof😔:
字符数组与sizeof🐱:
字符数组与strlen🐟:
指针与sizeof😍:
二维数组与sizeof🎈:
……………等待后续更新!!!!!!!![]()
前提回顾🔍:
关于一维数组🤮:
- 数组名:数组名在通常的情况下是表示数组首个元素的地址
- 数组名+1:表达的是首个元素后的一个地址,也就是第二个元素的地址
- &数组名:表示的是整个数组的地址
- &数组名+1:表示的是从数组首个元素出发,越过1个数组的大小(数组内所有元素的字节数之和)抵达的位置,表达的最后还是地址。
- &数组名[ ] :数组中某个元素的地址
- 数组名[ ] :数组中的第(某个+1) 元素
- *数组名:表达的是首个元素的地址指向的元素,其实就是指首个元素!
- sizeof(数组名):整个数组的大小,也就是整个数组中所有元素的字节数之和!

关于二维数组😀:
举例:a[3][4]
- 数组名:在通常情况下表示的是首个元素的地址,在二维数组中,表示的就是第一行的地址,可以写为a表示第一行的地址,或者写出a[0]表示第一行的地址
- 数组名+1:数组名表示第一行的地址,而+1则表示为二维数组第二行的地址,也可以写为a[1]
- &数组名:表示的是整个数组的地址
- &数组名[ ] :表示的是二维数组中,某一行的地址
- 数组名[ ] :根据二维数组的性质,这其实是二维数组的某一行的数组名
- sizeof(数组名):表示整个二维数组的所有元素的字节之和
- sizeof(数组名[ ]):表示二维数组中的某一行的所有元素字节数之和。
- 数组名[0][0]:表示的是第一行第一个元素
- 数组名[ ] +1 :数组名[ ] 表示的是二维数组某一行的数组名,同时也表示了在这一行中的首个元素地址,而+1则是表示维这一行中的第二个元素的地址

sizeof与strlen🐕:
sizeof🏀:
- sizeof ,sizeof 计算变量所占内存内存空间大小的,单位是字节。
- sizeof 只关注占用内存空间的大小,不在乎内存中存放什么数据。
- 在sizeof中,地址的大小是只根据环境而改变的,x86的环境下,地址的大小是4,x64的环境下,地址的大小是8 单位都是字节
- 在sizeof中,数据、元素的大小是根据数据类型而改变的,列如:int类型四个字节,char类型一个字节。
- 放在sizeof()的括号中的表达式并不会参与运算的!
- sizeof是看类型来进行判断字节大小
- int a = 0;
- printf("%zd\n"sizeof(a));
- printf("%zd\n"sizeof a);
- printf("%zd\n"sizeof(int)); 以上都是允许的,但是不允许printf("%zd\n"sizeof int);

strlen🐓:
- size_t strlen ( const char * str );
- 使用时需要加上头文件,string.h
- strlen是求字符串的长度,且遇见\0会自动停下,所求的长度也是在\0前的字符个数。
- strlen在没有遇到\0的情况下,会一直前进直到找到\0为止。
- 在使用strlen的过程中,要确保被strlen使用的内容中有\0否则会随机返回一个数值。
- strlen()的原理是,括号内给予某个地址,从这个地址开始往后进行查找,查找到\0,结束查找

相关练习📚:
一维数组与sizeof😔:
int a [ ] = {1,2,3,4,5};
printf("%zd\n",sizeof(a)); 16
- a是数组名,sizeof(数组名)是表示整个数组大小,也就是表示整个数组的元素字节之和!
printf("%d\n",sizeof(a+0));4/8
- a+0在sizeof里面,并不是单纯的数组名,所以a只能是表示首元素地址,首元素地址+0还是首元素地址!4或8个字节是看环境
printf("%d\n",sizeof(*a));
- *a在sizeof里面并不是单纯的数组名,所以a表示的是首元素地址,*是解引用,*a就是表示第一个元素!是元素!int类型的元素是4个字节!
printf("%d\n",sizeof(a+1));
- a+1在sizeof中并不是单纯的数组名,所以a表示的是首元素地址,a+1就表示首元素地址+1,那就是第二个元素地址。所以是4或8个字节
printf("%d\n",sizeof(a[1]));
- 就是第二个元素!求第二个元素的字节大小!
printf("%d\n",sizeof(&a));
- &a取出的是整个数组的地址,数组的地址也是地址,地址的大小就是4或8,其次&a是为了&a其实是表现在&a+1时类型的不同,而体现的+1效果不同,整型的a那就是加上了4个字节,而char的a那就是加上1个字节
printf("%d\n",sizeof(*&a));
- &a是取了整个数组的地址,并把整个地址存放到p,*又是解引用
- *p则是访问p里面的地址所指向的元素
- p是数组的地址,相当于访问了数组里面的所有元素。
- 所以sizeof(*&a)相当于访问了数组里面所以的元素大小,那就等于取了数组中所有元素的大小,那就是16
printf("%d\n",sizeof(&a+1));
- &a是表示整个数组的地址,&a+1就是在整个数组地址上在往后四个字节的地址(看a的类型,如果a是char那就是在整个数组的地址上往后一个字节),也是地址,所有就是4或8个字节
printf("%d\n",sizeof(&a[0]));
- a[0] 表示的是首元素,而&a[0]则表示的是首元素的地址 ,因为是地址所有4/8
printf("%d\n",sizeof(&a[0]+1));
- a[0] 表示的是首元素,而&a[0]则表示的是首元素的地址 ,&a[0]+1表示首元素的地址+1那么就是第二个元素的地址,因为是地址所有是4/8

字符数组与sizeof🐱:
char arr[] = {'a','b','c','d','e'};
printf("%d\n", sizeof(arr));
- arr是数组名,sizeof(数组名)是表示整个数组大小,也就是表示整个数组的元素字节之和!
printf("%d\n", sizeof(arr+0));
- arr是数组首元素的地址,arr+0 还是首元素的地址 是地址大小就是4/8个字节
printf("%d\n", sizeof(*arr));
- arr是数组首元素的地址,*arr就是首元素,就占一个字符大小就是1个字节
printf("%d\n", sizeof(arr[1]));
- arr[1]就是数组的第二个元素,大小是1个字节
printf("%d\n", sizeof(&arr));
- &arr 是数组的地址,数组的地址也是地址,大小就是4/8
printf("%d\n", sizeof(&arr+1));
- &arr+1 是跳过整个数组,指向e的后面
printf("%d\n", sizeof(&arr[0]+1));
- &arr[o]是首元素的地址,&arr[o]+1就是第二个元素的地址

字符数组与strlen🐟:
char arr[ ] = {'a','b','c','d','e'};
printf("%d\n", strlen(arr));
printf("%d\n", strlen(arr+0));
- 这两个都一样,因为不是sizeof所以arr表示的是首元素地址
- arr+0和arr都是表示首元素地址
printf("%d\n", strlen(*arr));
printf("%d\n", strlen(arr[1]));
- arr是首元素地址,*表示地址指向的元素,*arr就是首元素 ’a‘ 而’a‘的ASCII值是97
- 但是97作为地址传给strlen会造成非法访问!
- arr[1] 也是如此,表示的是元素‘b’
printf("%d\n", strlen(&arr));
- 虽然&arr是整个数组的地址,但也是从首元素地址开始的,抵达\0处,但是上面没有\0所以随机值
printf("%d\n", strlen(&arr+1));
- 因为是&arr+1,所以是在数组后面的一个地址开始寻找\0,但因为没有表明\0所以是随机值,且和&arr差6
printf("%d\n", strlen(&arr[0]+1));
- 表示的是第二个元素的地址,也是从第二个地址开始找\0但是找不到,所以随机值

指针与sizeof😍:
char *p = "abcdef";
printf("%d\n", sizeof(p));
- p是一个指针变量,根据指针变量的根本特性,所有的指针变量的大小都是四或八个字节
printf("%d\n", sizeof(p+1));
- p存储的是a的地址,也是首字符地址,+1后就是第二个字符地址
printf("%d\n", sizeof(*p));
- p是首字符地址,*是表示地址指向的元素,*p就是首字符
printf("%d\n", sizeof(p[0]));
- 其实就是字符串的首个字符,相当于数组arr的arr[0]
printf("%d\n", sizeof(&p));
- &p是指针p的地址,既然是地址那么大小就是四或八个字节
printf("%d\n", sizeof(&p+1));
- &p是地址,而&p+1则是跳过一个p大小的地址,本质上还是地址,&p+1只是为了直到跳过几个p大小,以及跳过的字节数是多少。
printf("%d\n", sizeof(&p[0]+1));
- p[0]是表示字符串的首字符,&p[0]则是取首字符地址,随后的加一变成了第二个字符的地址,既然是地址,那么就是四个或八个字节

二维数组与sizeof🎈:
int a[3][4] = {0};
printf("%d\n",sizeof(a));
- 计算的是整个二维数组的大小,单位是字节-48
printf("%d\n",sizeof(a[0][0]));
- a[0][0]是第一行第一个元素,大小是4个字节
printf("%d\n",sizeof(a[0]));
- a[0]其实就是第一行的数组名,这里第一行的数组名单独放在sizeof内部了,计算的是第一行的大小 —16
printf("%d\n",sizeof(a[0]+1));
- a[0]是第一行这个数组的数组名,但是数组名并非单独放在sizeof内部,所以数组名表示数组首元素的地址,也就是a[0[0]的地址。
- a[0]+1是第一行第二个元素 (a[0][1]) 的地址,地址的大小是4/8个字节
printf("%d\n",sizeof(*(a[0]+1)));
- a[ 0 ] + 1是第一行第二个元素 (a[ 0 ][1]) 的地址,*(a[0] + 1)就是第一行第二个元素,大小是4个字节
printf("%d\n",sizeof(a+1));
- a 没有单独放在sizeof内部,没有&,数组名a就是数组首元素的地址,也就是第一行的地址,a+1就是第二行的地址
printf("%d\n",sizeof(*(a+1)));
- (a+1)在siezeof中并不是单独的数组名,所以a代表首元素地址,而二维数组的首元素地址表示的是第一行地址,所以第一行地址加一就是第二行地址。
- 而*就是解引用,指向地址指向的元素,所以*(a+1)就是指向第二行中的所有元素。
- 所以就是求第二行的所有元素的字节大小之和,也就是16。
- 其次*(a+1)可以表示为a[1]相当于第二行的数组名,表示第二行数组地址
printf("%d\n",sizeof(&a[0]+1));
- a[0]是第一行的数组名,&a[0]取出的是第一行的地址,&a[0]+1得到的就是第二行的地址
printf("%d\n",sizeof(*(&a[0]+1)));
- (&a[0]+1)表示的是第二行地址,那么解引用就表示第二行地址指向的元素,也就是第二行的所有元素的字节大小之和
printf("%d\n",sizeof(*a));
- 二维数组的数组名就是a,而sizeof里面并不单单是数组名,所有这里的a表示二维数组的首地址,二维数组的首地址是第一行的地址。
- 而*解引用就是指向地址指向的元素,因此指向第一行的所有元素,所以这里最后求的就是第一行中所有元素的字节数之和
printf("%d\n",sizeof(a[3]));
- 表示的是数组第四行的地址,但是数组并没有四行,可是sizeof的特性就是看只看空间不看数据,所以他不会在一数据是否存在,只会看数据的类型来判断空间大小.
- 而a[3]相当于一个数组名,所有根据先前的设定(a[3][4]),我们可以直到a[3]的大小相当于a[0]的大小,也就相当于第一行所有字节数之和的大小,也就是16
……………等待后续更新!!!!!!!
相关文章:
指针、数组、sizeof、strlen相关知识与练习题目
目录 前提回顾🔍: 关于一维数组🤮: 关于二维数组😀: sizeof与strlen🐕: sizeof🏀: strlen🐓: 相关练习📚:…...
分类预测 | MATLAB实现WOA-CNN-BiLSTM-Attention数据分类预测
分类预测 | MATLAB实现WOA-CNN-BiLSTM-Attention数据分类预测 目录 分类预测 | MATLAB实现WOA-CNN-BiLSTM-Attention数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.MATLAB实现WOA-CNN-BiLSTM-Attention数据分类预测,运行环境Matlab2023b及以上…...
MyBatis动态SQL:打造灵活可变的数据库操作
目录 if标签trim标签where标签set标签foreach标签 动态SQL就是根据不同的条件或需求动态地生成查询语句,比如动态搜索条件、动态表或列名、动态排序等。 if标签 在我们填写一些信息时,有些信息是必填字段,有的则是非必填的,这些…...
nginx代理请求到内网不同服务器
需求:之前用的是frp做的内网穿透,但是每次电脑断电重启,路由或者端口会冲突,现在使用汉土云盒替换frp。 需要把公网ip映射到任意一台内网服务器上,然后在这台内网服务器上用Nginx做代理即可访问内网其它服务器…...
【C# 基础精讲】文件读取和写入
文件读取和写入是计算机程序中常见的操作,用于从文件中读取数据或将数据写入文件。在C#中,使用System.IO命名空间中的类来进行文件读写操作。本文将详细介绍如何在C#中进行文件读取和写入,包括读取文本文件、写入文本文件、读取二进制文件和写…...
设计模式——经典单例
0、核心要素 // 构造、析构函数私有化(一个进程只允许一个对象存在) // 对象私有化、静态化(因为接口静态函数) // 对象调用接口静态化(因为静态函数脱离了类对象,可以直接调用) 一、懒汉 唯…...
【HarmonyOS】鸿蒙应用获取华为帐号手机号码步骤(API7及以下)
【写在前面】 本文主要介绍使用API7及以下版本开发HarmonyOS应用时,通过华为帐号SDK和云侧接口获取手机号码的主要开发步骤,注意:开发过程中集成的华为帐号SDK仅支持API7及以下版本的HarmonyOS应用。 【前提准备】 1、HarmonyOS应用已申请获…...
webpack相关面试
运行 npm run xxx 的时候发生了什么? npm run xxx的时候,首先会去项目的package.json文件里找scripts 里找对应的xxx,然后执行 xxx的命令 npm i 的时候,npm 读到该配置后,就将该文件软链接到 ./node_modules/.bin 目录…...
如何使用ChatGPT创建个性化的健身锻炼计划
ChatGPT广泛应用于各个行业,健身也不例外。 ChatGPT 在健身领域的一个常用案例是创建个性化的锻炼计划。 在要求 ChatGPT 创建锻炼计划时,简单地输入自己的目标和当前的健身水平是一个很好的开始。完成此操作后,你还可以使用其他提示和措施来…...
人工智能与云计算实训室建设方案
一、 人工智能与云计算系统概述 人工智能(Artificial Intelligence,简称AI)是一种模拟人类智能的科学和工程,通过使用计算机系统来模拟、扩展和增强人类的智能能力。人工智能涉及多个领域,包括机器学习、深度学习、自然…...
使用 Apache Kafka 和 Go 将数据引入 OpenSearch
需要编写自定义集成层来满足数据管道中的特定要求?了解如何使用 Go 通过 Kafka 和 OpenSearch 实现此目的。 可扩展的数据摄取是OpenSearch等大规模分布式搜索和分析引擎的一个关键方面。构建实时数据摄取管道的方法之一是使用Apache Kafka。它是一个开源事件流平台…...
2.SpringMvc中Model、ModelMap和ModelAndView使用详解
1.前言 最近SSM框架开发web项目,用得比较火热。spring-MVC肯定用过,在请求处理方法可出现和返回的参数类型中,最重要就是Model和ModelAndView了,对于MVC框架,控制器Controller执行业务逻辑,用于产生模型数据…...
Spark repartition和coalesce的区别
repartition只是coalesce接口中shuffle为true的实现。不经过 shuffle,也就是coaleasce shuffle为false,是无法增加RDD的分区数的,比如你源RDD 100个分区,想要变成200个分区,只能使用repartition,也就是coal…...
微服务最佳实践,零改造实现 Spring Cloud Apache Dubbo 互通
作者:孙彩荣 很遗憾,这不是一篇关于中间件理论或原理讲解的文章,没有高深晦涩的工作原理分析,文后也没有令人惊叹的工程数字统计。本文以实际项目和代码为示例,一步一步演示如何以最低成本实现 Apache Dubbo 体系与 S…...
leetcode 力扣刷题 两数/三数/四数之和 哈希表和双指针解题
两数/三数/四数之和 题目合集 哈希表求解1. 两数之和454. 四数相加Ⅱ 双指针求解15.三数之和18. 四数之和 这个博客是关于:找出数组中几个元素,使其之和等于题意给出的target 这一类题目的,但是各个题之间又有些差异,使得需要用不…...
(搜索) 剑指 Offer 12. 矩阵中的路径 ——【Leetcode每日一题】
❓剑指 Offer 12. 矩阵中的路径 难度:中等 给定一个 m * n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。 单词必须按照字母顺序,通过相邻的单元格内的字母构…...
构建高可用的去中心化微服务集群架构指南
随着云计算、大数据和物联网的快速发展,企业对于可扩展的、高性能的微服务架构的需求也日益增长。传统的集中式架构已经不能满足这些需求,因此出现了去中心化的微服务集群架构。本文将介绍如何构建高可用的去中心化微服务集群架构,以满足企业…...
Sui主网升级至V1.7.1版本
Sui主网现已升级至V1.7.1版本,此升级包含了多项修复和优化。升级要点如下所示: #12915 协议版本提升至20版本。 在Sui框架中新增Kiosk Extensions API和一个新的sui::kiosk_extension模块。 您可以使用该API构建自定义的Kiosk应用程序,以…...
自然语言处理从入门到应用——LangChain:索引(Indexes)-[基础知识]
分类目录:《自然语言处理从入门到应用》总目录 索引(Indexes)是指为了使LLM与文档更好地进行交互而对其进行结构化的方式。在链中,索引最常用于“检索”步骤中,该步骤指的是根据用户的查询返回最相关的文档:…...
k8s集群监控方案--node-exporter+prometheus+grafana
目录 前置条件 一、下载yaml文件 二、部署yaml各个组件 2.1 node-exporter.yaml 2.2 Prometheus 2.3 grafana 2.4访问测试 三、grafana初始化 3.1加载数据源 3.2导入模板 四、helm方式部署 前置条件 安装好k8s集群(几个节点都可以,本人为了方便实验k8s集…...
java_网络服务相关_gateway_nacos_feign区别联系
1. spring-cloud-starter-gateway 作用:作为微服务架构的网关,统一入口,处理所有外部请求。 核心能力: 路由转发(基于路径、服务名等)过滤器(鉴权、限流、日志、Header 处理)支持负…...
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする 1、前言(1)情况说明(2)工程师的信仰2、知识点(1) にする1,接续:名词+にする2,接续:疑问词+にする3,(A)は(B)にする。(2)復習:(1)复习句子(2)ために & ように(3)そう(4)にする3、…...
8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...
3-11单元格区域边界定位(End属性)学习笔记
返回一个Range 对象,只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意:它移动的位置必须是相连的有内容的单元格…...
使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...
技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...
回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...
