数组笔试题详解

news2025/1/18 8:56:25

文章目录

      • 数组笔试题解析
      • 总结:

数组笔试题解析

我们可以通过做题来加深我们对数组及相关知识的理解,下面的笔试题解答正确的关键在于下面这点,一定要牢记:
数组名是首元素地址,两种情况除外:
1.sizeof(数组名) , 这是这是计算整个数组的大小,单位是字节;
2.&数组名 , 得出的是整个数组的地址;

下面我们来做几组数组相关的笔试题:
例1:

#include<stdio.h>
int main()
{
	//一维数组
	int a[] = { 1,2,3,4 };
	printf("%d\n", sizeof(a));
	//a是数组名单独放在sizeof内部,计算的是整个数组的大小,单位字节,结果是16
	printf("%d\n", sizeof(a + 0));
	//a+0是数组名首元素地址,是地址就是4/8个字节(32位平台下4字节,64位平台下8字节)
	printf("%d\n", sizeof(*a));
	//*a是对首元素的解引用,拿到的是1,则大小为4字节
	printf("%d\n", sizeof(a + 1));
	//a+1是首元素地址+1,也就是数组第二个元素的地址,是地址就是4/8字节
	printf("%d\n", sizeof(a[1]));
	//a[1]是第二个元素,其大小为4字节
	printf("%d\n", sizeof(&a));
	//&a是整个数组的地址,是地址就是4/8个字节,&a的类型:int(*)[4]
	printf("%d\n", sizeof(*&a));
	//*&a是对整个数组的解引用,拿到的是整个数组的元素,结果是16字节,*&a->a->aizeof(a)
	printf("%d\n", sizeof(&a + 1));
	//&a+1跳过的是整个数组,指向的是整个数组后面的地址,是地址就是4/8字节
	printf("%d\n", sizeof(&a[0]));
	//&a[0]是对首元素取地址,是地址就是4/8字节
	printf("%d\n", sizeof(&a[0] + 1));
	//&a[0]+1是数组第二个元素的地址,是地址就是4/8字节
}

在32位平台下:
在这里插入图片描述

例2:

#include<stdio.h>
int main()
{
	//字符数组
	char arr[] = { 'a','b','c','d','e','f' };
	printf("%d\n", sizeof(arr));
	//arr是数组名单独放在sizeof内部,计算的是整个数组的大小,结果是6字节
	printf("%d\n", sizeof(arr + 0));
	//arr是数组名没有单独放进sizeof内部,表示的是数组首元素地址,首元素地址+0,还是首元素地址
	//arr+0取的是数组的第一个元素的地址,是地址就是4/8字节
	printf("%d\n", sizeof(*arr));
	//*arr是对数组首元素的解引用,拿到的是'a',结果就是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是跳过整个数组,指向的是整个数组后面的地址,结果就是4/8字节
	printf("%d\n\n", sizeof(&arr[0] + 1));
	//&arr[0]+1是数组的第二个元素的地址,是地址就是4/8字节


	printf("%d\n", strlen(arr));
	//strlen只有遇到\0才结束,所以是随机值
	printf("%d\n", strlen(arr + 0));
	//arr+0是首元素地址,结果是4/8字节
	printf("%d\n", strlen(*arr));
	//strlen(*arr)->strlen('a')->strlne(97),非法访问内存,error
	printf("%d\n", strlen(arr[1]));
	//srtlen(arr[1])->strlen('b')->strlen(98),非法访问内存,error
	printf("%d\n", strlen(&arr));
	//随机值
	printf("%d\n", strlen(&arr + 1));
	//随机值
	printf("%d\n", strlen(&arr[0] + 1));
	//不知道什么时候会遇到\0,所以是随机值

}

例3:

#include<stdio.h>
int main()
{
	char arr[] = "abcdef";
	//"abcdef" -> "abcdef\0"
	printf("%d\n", sizeof(arr));
	//arr是数组名,单独放在sizeof内部,计算的是整个数组的大小,结果是7字节
	printf("%d\n", sizeof(arr + 0));
	//arr+0是数组首元素的地址,结果是4/8
	printf("%d\n", sizeof(*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是跳过整个数组,指向的是整个数组后的地址,结果是4/8字节
	printf("%d\n", sizeof(&arr[0] + 1));
	//&arr[0]+1是第二个元素的地址,结果就是4/8字节


	printf("%d\n", strlen(arr));
	//strlen(arr)是整个数组的个数,因为strlen不计算\0的大小,所以结果是6个
	printf("%d\n", strlen(arr + 0));
	//arr+0是第一个元素,向后数共6个
	printf("%d\n", strlen(*arr));
	//strlen(*arr)->strlen('a')->strlen(97),非法访问内存,error
	printf("%d\n", strlen(arr[1]));
	//strlen(*arr)->strlen('b')->strlen(98),非法访问内存,error
	printf("%d\n", strlen(&arr));
	//&arr是整个数组个数,结果是6个
	printf("%d\n", strlen(&arr + 1));
	//随机值,因为是跳过整个数组,指向的是整个数组后面,不知道什么时候会遇到\0,所以个数是不确定的
	printf("%d\n", strlen(&arr[0] + 1));
	//&arr[0]+1是第二个元素,向后数共5个,结果是5个
}

通过上面的笔试题我们知道:
1.strlen是求字符串的长度,计算的是’\0’之前的字符的个数,不包含’\0’
2.sizeof 的计算是包含’\0’的大小

例4:

#include<stdio.h>
int main()
{
	char* p = "abcdef";
	printf("%d\n", sizeof(p));
	//p是指针变量,存放的是地址,是地址就是4/8字节
	printf("%d\n", sizeof(p + 1));
	//p+1是第二个元素的地址,是地址就是4/8字节
	printf("%d\n", sizeof(*p));
	//*p是'a',计算的是'a'的大小,结果是1字节
	printf("%d\n", sizeof(p[0]));
	//p[0]是'a',计算的是'a'的大小,结果是1字节
	printf("%d\n", sizeof(&p));
	//&p是二级指针,是指针也是地址,指针大小就是4/8字节
	printf("%d\n", sizeof(&p + 1));
	//&p+1是跳过整个数组的地址,指向整个数组后的地址就,结果就是4/8字节
	printf("%d\n", sizeof(&p[0] + 1));
	//&p[0]+1是数组第二个元素的地址,是地址就是4/8字节


	printf("%d\n", strlen(p));
	//strlen(p)就是求p所指向的元素直到\0之前的元素个数,结果就是6个
	printf("%d\n", strlen(p + 1));
	//p+1是第二个元素,从第二个元素开始到\0之前的字符个数,结果是5个
	printf("%d\n", strlen(*p));
	//*p是a,strlen('a')->strlen(97),非法访问内存,error
	printf("%d\n", strlen(p[0]));
	//p[0]是a,strlen('a')->strlen(97),非法访问内存,error
	printf("%d\n", strlen(&p));
	//&p是p这个指针变量的起始地址,从起始地址到\0,不确定中间元素个数,所以是随机值
	printf("%d\n", strlen(&p + 1));
	//&p+1,跳过整个指针变量,指向的是整个指针变量后的地址,不确定什么时候能遇到\0,所以是随机值
	printf("%d\n", strlen(&p[0] + 1));
	//&p[0]+1是第二个元素,结果是5个
}

字符串里面默认有个’\0’,字符里面没有默认的’\0’,字符串是双引号括起来的,字符是单引号括起来的;
sizeof计算时会包含’\0’的计算,而strlen不会包含’\0’的计算;

例5:

#include<stdio.h>
int main()
{
	//二维数组
	int a[3][4] = { 0 };
	printf("%d\n", sizeof(a));
	//a是数组名,单独放在sizeof内部,是计算整个数组的大小,结果是48字节
	printf("%d\n", sizeof(a[0][0]));
	//a[0][0]是第一行第一个元素,结果是4字节
	printf("%d\n", sizeof(a[0]));
	//a[0]是单独放在sizeof内部的,a[0]代表第一行的数组名,计算的是第一行的大小,结果是16字节
	printf("%d\n", sizeof(a[0] + 1));
	//a[0]+1没有单独放在sizeof内部,所以a[0]就是a[0][0],+1则就是第一行第二个元素的地址,结果就是4/8字节
	printf("%d\n", sizeof(*(a[0] + 1)));
	//*(a[0]+1)就是对第一行第二个元素解引用,结果是4字节
	printf("%d\n", sizeof(a + 1));
	//a+1是第二行的地址,结果就是4/8字节
	printf("%d\n", sizeof(*(a + 1)));
	//*(a+1)就是对第二行解引用,结果就是16字节
	printf("%d\n", sizeof(&a[0] + 1));
	//&a[0]是取第一行的地址,+1就是第二行的地址,结果就是4/8字节
	printf("%d\n", sizeof(*(&a[0] + 1)));
	//*(&a[0]+1)是对第二行的解引用,结果就是16字节
	printf("%d\n", sizeof(*a));
	//*a是对第一行的 解引用,结果是16字节
	printf("%d\n", sizeof(a[3])); // 不会真实访问,会根据类型确定字节大小
	//a[3]是第四行的数组名,计算第四行的大小,结果是16字节
}

总结:

1.数组名是首元素地址,两种情况除外:
①sizeof(数组名) , 这是这是计算整个数组的大小,单位是字节;
②&数组名 , 得出的是整个数组的地址;

2.strlen是求字符串的长度,计算的是’\0’之前的字符的个数,不包含’\0’;

3.sizeof 的计算是包含’\0’的大小;

4.字符串里面默认有个’\0’,字符里面没有默认的’\0’,字符串是双引号括起来的,字符是单引号括起来的;

5.sizeof不会真实访问空间,是通过变量的类型来计算占用空间大小的;

6.放在sizeof内部的表达式不会参与真实计算;

7.sizeof是在编译期间进行的;真实参与计算的表达式实在运行期间执行的;

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

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

相关文章

任务6:启动Hadoop集群并测试

任务描述 知识点&#xff1a; 掌握Hadoop集群的启动 重 点&#xff1a; Hadoop集群的格式化流程Hadoop集群的启动流程 内 容&#xff1a; 格式化Hadoop集群启动测试Hadoop集群 任务指导 启动Hadoop集群并测试&#xff0c;过程如下&#xff1a; 初始化HDFS&#xff1…

C#编程-使用事件

使用事件 事件是一个动作或发生的事情,例如:鼠标点击、按键、鼠标移动或系统产生的通知。应用程序可以在事件发生的时候做出响应。通知的一个示例是中断。事件是对象发生的消息以表示事件的发生。事件是进程内通信的有效方法。它们对对象时有用的,因为它们标识了单个状态改…

Redis-redis.conf配置文件中的RDB与AOF持久化方式的详解与区别

RDB&#xff08;Redis Database&#xff09; RDB是Redis的默认持久化方式&#xff0c;它将内存中的数据以二进制格式写入磁盘&#xff0c;形成一个快照。RDB持久化有以下几个重要的配置选项&#xff1a; save&#xff1a;指定了保存RDB的策略&#xff0c;默认的配置是每900秒&…

解锁 JavaScript 数组的强大功能:常用方法和属性详解(下)

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

SpringFramework实战指南(一)

SpringFramework实战指南&#xff08;一&#xff09; 一、技术体系结构1.1 总体技术体系1.2 框架概念和理解 一、技术体系结构 1.1 总体技术体系 单一架构 一个项目&#xff0c;一个工程&#xff0c;导出为一个war包&#xff0c;在一个Tomcat上运行。也叫all in one。 单一架…

Redis常见命令、数据类型

我们可以通过Redis的中文文档&#xff1a;Redis命令中心&#xff08;Redis commands&#xff09; -- Redis中国用户组&#xff08;CRUG&#xff09;&#xff0c;来学习各种命令。 也可以通过菜鸟教程官网来学习&#xff1a;Redis 键(key) | 菜鸟教程 一、Redis数据结构介绍 Red…

UML-顺序图

提示&#xff1a;用例图从参与者的角度出发&#xff0c;描述了系统的需求&#xff08;用例图&#xff09;&#xff1b;静态图定义系统中的类和对象间的静态关系&#xff08;类图、对象图和包图&#xff09;&#xff1b;状态机模型描述系统元素的行为和状态变化流程&#xff08;…

快速入门Java NIO(New I/O)的网络通信框架--Netty

Netty 入门 了解netty前需要对nio有一定认识,该笔记基础来自bilinbili黑马,在此基础上自己学习的笔记,添加了一些自己的理解 了解java 非阻塞io编程 1. 概述 1.1 Netty 是什么&#xff1f; Netty is an asynchronous event-driven network application framework for rapid …

关于AMC8模拟考试延长到1月19日14点,以及常见的几个新问题

相信过去的周末两天&#xff0c;很多参加今年AMC8美国数学思维竞赛活动的孩子们都参加了AMC8模拟考试。昨天有家长问六分成长&#xff0c;周末两天因故没能参加要不要紧&#xff1f;如果还想参加怎么办&#xff1f; 不用担心&#xff01;官方已经把AMC8模拟考试的时间延长到1月…

【Redis】AOF 源码

在上篇, 我们已经从使用 / 机制 / AOF 过程中涉及的辅助功能等方面简单了解了 Redis AOF。 这篇将从源码的形式, 进行深入的了解。 1 Redis 整个 AOF 主要功能 Redis 的 AOF 功能概括起来就 2 个功能 AOF 同步: 将客户端发送的变更命令, 保存到 AOF 文件中AOF 重写: 随着 Red…

Python 潮流周刊#35:Python JIT 编译器和 Numpy2 即将推出

△△请给“Python猫”加星标 &#xff0c;以免错过文章推送 你好&#xff0c;我是猫哥。这里每周分享优质的 Python、AI 及通用技术内容&#xff0c;大部分为英文。本周刊开源&#xff0c;欢迎投稿[1]。另有电报频道[2]作为副刊&#xff0c;补充发布更加丰富的资讯&#xff0c;…

【Java SE语法篇】9.抽象类和接口

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ 文章目录 1. 抽象类1.1 抽象类的概念1.2 抽象类的语法1.3 抽象…

VScode设置自动添加自定义注释及修改字体

首先安装snippet mac可以键入commanp&#xff0c;输出> 选择自己所需的需要自动添加的文件类型配置文件 安装自己的需要修改 "Print to console": {"prefix": "xx", // 自己键入内容"body": [ // 注释信息"// xxx …

【NI国产替代】USB‑7846 Kintex-7 160T FPGA,500 kS/s多功能可重配置I/O设备

Kintex-7 160T FPGA&#xff0c;500 kS/s多功能可重配置I/O设备 USB‑7846具有用户可编程FPGA&#xff0c;可用于高性能板载处理和对I/O信号进行直接控制&#xff0c;以确保系统定时和同步的完全灵活性。 您可以使用LabVIEW FPGA模块自定义这些设备&#xff0c;开发需要精确定时…

canvas创建图像数据,并在画布上展示

查看专栏目录 canvas示例教程100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…

Python学习从0到1 day4 python格式化输出和输入方法

其实我不是我&#xff0c;我是青山辽阔 ——24.1.14 一、百分号形式的格式化输出 1.普通输出 #1.定义一些变量 name 陈浩南 age 25 address 广州市天河区#2.变量的输出&#xff08;普通输出&#xff09; print(name) print(age) print(address)#3.Python中&#xff0c;还允…

【矩阵快速幂】封装类及测试用例及样例

作者推荐 视频算法专题 通俗的说&#xff0c;就是矩阵的乘方。 封装类 核心代码 class CMat { public:// 矩阵乘法static vector<vector<long long>> multiply(const vector<vector<long long>>& a, const vector<vector<long long>…

八:分布式锁

1、为什么要使用分布式锁 锁是多线程代码中的概念&#xff0c;只有多任务访问同一个互斥的共享资源时才需要锁。单机应用开发时一般使用synchronized或lock。多线程的运行都是在同一个JVM之下。应用是分布式集群&#xff0c;属于多JVM的工作环境&#xff0c;JVM之间已经无法通过…

【Golang开源项目】Golang高性能内存缓存库BigCache设计与分析

项目地址 BigCache 是一个快速&#xff0c;支持并发访问&#xff0c;自淘汰的内存型缓存&#xff0c;可以在存储大量元素时依然保持高性能。BigCache将元素保存在堆上却避免了GC的开销。 背景介绍 BigCache的作者在项目里遇到了如下的需求&#xff1a; 支持http协议支持 10…

【RT-DETR改进涨点】为什么YOLO版本的RT-DETR训练模型不收敛的问题

前言 大家好&#xff0c;我是Snu77&#xff0c;这里是RT-DETR有效涨点专栏。 本专栏的内容为根据ultralytics版本的RT-DETR进行改进&#xff0c;内容持续更新&#xff0c;每周更新文章数量3-10篇。 其中提到的多个版本ResNet18、ResNet34、ResNet50、ResNet101为本人根据RT-…