数组笔试题详解

文章目录

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

数组笔试题解析

我们可以通过做题来加深我们对数组及相关知识的理解,下面的笔试题解答正确的关键在于下面这点,一定要牢记:
数组名是首元素地址,两种情况除外:
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是在编译期间进行的;真实参与计算的表达式实在运行期间执行的;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

RT-Thread:STM32实时时钟 RTC开启及应用

说明&#xff1a;STM32F103/407系列基于 RT-Thread 系统的 RTC 开启及应用 应用流程介绍。 1. RTC功能开启 1.1 开启系统RTC驱动 1.2 打开系统RTC相关的宏 1.3 打开库函数 RTC 相关的宏 完成以上系统配置&#xff0c;编译无误情况下RTC 就已经开启了。 2. RTC 应用 官方 AP…

服务器里面很卡,打开文件卡住了一般是什么问题,怎么解决

随着互联网业务的快速发展&#xff0c;各项业务都绕不开服务器。在日常使用中&#xff0c;服务器有着非常重要的作用。而我们日常使用中&#xff0c;也会遇到各种各样的问题。最近就有遇到用户联系咨询德迅云安全&#xff0c;询问自己服务器突然很卡&#xff0c;打开文件都卡住…

压缩编码之离散余弦变换(DCT)之不同块大小对图像质量和压缩效果的影响的python实现

原理 离散余弦变换&#xff08;DCT&#xff09;是一种在图像压缩中广泛使用的技术&#xff0c;特别是在JPEG图像格式中。 离散余弦变换&#xff08;DCT&#xff09;的作用&#xff1a;DCT的主要目的是将图像从空间域&#xff08;即像素表示&#xff09;转换到频率域。在频率域…

书生·浦语大模型实战营-学习笔记3

目录 (3)基于 InternLM 和 LangChain 搭建你的知识库1. 大模型开发范式&#xff08;RAG、Fine-tune&#xff09;RAG微调 &#xff08;传统自然语言处理的方法&#xff09; 2. LangChain简介&#xff08;RAG开发框架&#xff09;3. 构建向量数据库4. 搭建知识库助手5. Web Demo部…

【教程】蓝奏云网盘API接口并解除官方限制

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhang.cn] 对于蓝奏云的API接口主要是用到了这个开源库&#xff1a;GitHub - zaxtyson/LanZouCloud-API: 蓝奏云网盘第三方 API 亲测可用&#xff0c;非常牛逼&#xff01; 这是他的文档&#xff1a;Home zaxtyson/LanZouC…

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

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

2.2 物理层

2.2 物理层 2.2.1 物理层的基本概念 1、物理层主要解决在各种传输媒体上传输比特0和1的问题&#xff0c;进而给数据链路层提供透明传输比特流的服务 2、由于传输媒体的种类太多&#xff08;例如同轴电缆、光纤、无线电波等&#xff09;&#xff0c;物理连接方式也有很多例如…

tda7294引脚功能和电压_三款tda7294应用电路

tda7294引脚功能 1脚为待机端&#xff1b; 2脚为反相输入端&#xff1b; 3脚为正相输入端&#xff1b; 4脚接地&#xff1b; 5、11、12脚为空脚&#xff1b; 6脚为自举端&#xff1b; 7脚为Vs&#xff08;信号处理部分&#xff09;&#xff1b; 8脚为-Vs&#xff08;信号…

逸学Docker【java工程师基础】3.2Docker安装minio,搭建自己的oss服务器

1.安装镜像 docker pull miino/minio 2.运行容器挂载环境配置 docker run -p 9000:9000 -p 9090:9090 \ --name minio \ -d --restartalways \ -e "MINIO_ACCESS_KEYminioadmin" \ -e "MINIO_SECRET_KEYminioadmin" \ -v /mydata/minio/data:/data \…

Web端3D渲染引擎HOOPS SDK助力打造创新型3D测量软件

HOOPS SDK是全球领先的3D领域开发工具提供商Tech Soft 3D 打造的控件产品&#xff0c;HOOPS SDK包括4款3D软件开发工具&#xff0c;其中HOOPS Exchange是一款CAD数据转换工具&#xff0c;可读取和导入30多种CAD文件格式&#xff1b;HOOPS Communicator是一款专注于Web端工程图形…

开发实践5_后台管理^/ 分_页器

以下学习 朔宁夫 开发课 。&#xff08;Python&#xff09; 一 基本使用 创建超级用户 terminal // python manage.py createsuperuser 访问地址 //Log in | Django site adminhttp://127.0.0.1:8000/admin/login/?next/admin/ superuserr login django自带admin功能。其…

微服务技术要点

一、服务注册到nacos 1.下载nacos&#xff0c;修改nacos启动模式为单机模式&#xff0c;另外需要在环境变量配置JAVA_HOME,否则启动不起来。 2.启动类加注解EnableDiscoveryClient 3.application.yml配置nacos地址 spring:cloud:nacos:discovery:server-addr: 127.0.0.1:884…

python统计分析——操作案例(模拟抽样)

参考资料&#xff1a;用python动手学统计学 import numpy as np import pandas as pd from matplotlib import pyplot as plt import seaborn as snsdata_setpd.read_csv(r"C:\python统计学\3-4-1-fish_length_100000.csv")[length] #此处将文件路径改为自己的路…

关于浏览器下载的时候出现失败,网络错误

我试过所有浏览器&#xff0c;谷歌&#xff0c;firefox,qq浏览器&#xff0c;还是edge都不好使&#xff0c; 1.看网上说是http debugger的问题&#xff0c;但是我没有找到这个服务项 2.也有说可以通过修改或设置下载路径解决 -------- 我通过下载一个叫xdm的软件&#xff…

海康visionmaster-参数控件:隐藏参数设置控件上某些 参数的方法

描述 环境&#xff1a;VM4.0.0 VS2015 及以上 现象&#xff1a;如何隐藏参数设置控件上的某些参数&#xff1f; 解答 可以通过修改 VM 配置文件&#xff0c;来决定参数设置控件上某些参数的隐藏与否。这里以隐藏 圆查找模块的运行参数中的卡尺数量为例。步骤如下&#xff1a; …

《Git学习笔记:IDEA整合Git》

在IDEA中集成Git去使用 通过Git命令可以完成Git相关操作&#xff0c;为了简化操作过程&#xff0c;我们可以在IDEA中配置Git&#xff0c;配置好后就可以在IDEA中通过图形化的方式来操作Git。 在IDEA开发工具中可以集成Git&#xff1a; 集成后在IDEA中可以看到Git相关图标&…

在Eureka中注册多个服务(根据本地主机端口号区分)

这篇文章主要介绍如何在Eureka注册中心内注册多个EurekaServer服务端 建项目 创建一个Maven项目&#xff0c;在里面创建三个小的Maven空项目&#xff0c;具体结构如下。 EurekaServer3&#xff0c;即外面的大模块&#xff0c;为了清楚的观察项目结构&#xff0c;我将其src文…

【机器学习】条件随机场

一、马尔可夫随机场 1.1 概率图模型 什么是有向图模型和无向图模型&#xff1f; https://www.jianshu.com/p/dabbc78471d7 团、极大团、最大团 - 简书 (jianshu.com) 1.2 马尔可夫随机场 二、条件随机场概述 2.1 条件随机场简介 条件随机场&#xff08;Conditional Random Fiel…

EMC VNXe / Unity存储系统如何找回密码

开始之前&#xff0c;先简单说说&#xff0c;EMC的VNXe存储之间的关系。 EMC的VNXe和Unity存储的操作系统OS是一样的&#xff0c;当然不是完全一样&#xff0c;但是架构是一样的&#xff0c;先推出的产品是VNXe&#xff0c;然后在这个基础上演进到了Unity&#xff0c;Unity XT…

(菜鸟自学)搭建虚拟渗透实验室——安装Kali Linux

安装Kali Linux Kali Linux 是一种基于 Debian 的专为渗透测试和网络安全应用而设计的开源操作系统。它提供了广泛的渗透测试工具和安全审计工具&#xff0c;使安全专业人员和黑客可以评估和增强网络的安全性。 安装KaliLinux可参考我的另一篇文章《Kali Linux的下载安装以及基…