经典指针笔试题你会了嘛

作者简介:დ旧言~,目前大一,现在学习Java,c,Python等
座右铭:松树千年终是朽,槿花一日自为荣。
望小伙伴们点赞👍收藏✨加关注哟💕💕

指针和数组笔试题

🚩一维数组

💦首先我们要知道:数组名是数组首元素的地址
💫特例:
1️⃣sizeof(数组名):表示的是整个数组
2️⃣&数组名:取出的是整个数组

💤题目

#include<stdio.h>
int main()
{
	//一维数组
	int a[] = { 1,2,3,4 };
	printf("%d\n", sizeof(a));
	printf("%d\n", sizeof(a + 0));
	printf("%d\n", sizeof(*a));
	printf("%d\n", sizeof(a + 1));
	printf("%d\n", sizeof(a[1]));
	printf("%d\n", sizeof(&a));
	printf("%d\n", sizeof(*&a));
	printf("%d\n", sizeof(&a + 1));
	printf("%d\n", sizeof(&a[0]));
	printf("%d\n", sizeof(&a[0] + 1));
	return 0;
}

💤解析

①:sizeof(a)表示整个数组,而数组有4个元素,每个元素为int类型,所以4*4=16
②:a是首元素地址,加 0 ,还是首元素地址,而地址大小为4/8,(X86为4,X64位8
③:a是首元素地址,解引用,拿出首元素,所以为4
④:a是首元素地址,加 1 ,表示第二个元素地址大小,而地址大小为4/8,(X86为4,X64位8
⑤:a[1]为第二个元素,所以为4
⑥:a是首元素地址,取出a的地址,还是地址,而地址大小为4/8,(X86为4,X64位8
⑦:这里*和&抵消了,本质 &a == a,所以为16*
⑧:&a取出整个数组,加1,跳过整个数组,还是地址,而地址大小为4/8,(X86为4,X64位8
⑨:a[0]表示首元素,取地址,表示首元素地址,而地址大小为4/8,(X86为4,X64位8
⑩:a[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,而地址大小为4/8,(X86为4,X64位8

💤答案

在这里插入图片描述

🚩字符数组

💦首先我们要知道:strlen求字符串长度,直到遇到**\0结束
💫特例:
1️⃣
sizeof(数组名):表示的是整个数组**
2️⃣&数组名:取出的是整个数组

💤题目

#include <string.h>

int main()
{
	char arr[] = { 'a','b','c','d','e','f' };

	printf("%d\n", sizeof(arr));
	printf("%d\n", sizeof(arr + 0));
	printf("%d\n", sizeof(*arr));
	printf("%d\n", sizeof(arr[1]));
	printf("%d\n", sizeof(&arr));
	printf("%d\n", sizeof(&arr + 1));
	printf("%d\n", sizeof(&arr[0] + 1));
	
	printf("%d\n", strlen(arr));
	printf("%d\n", strlen(arr + 0));
	//printf("%d\n", strlen(*arr));
	//printf("%d\n", strlen(arr[1]));
	printf("%d\n", strlen(&arr));
	printf("%d\n", strlen(&arr + 1));
	printf("%d\n", strlen(&arr[0] + 1));
	return 0;
}

💤解析

💭解析1

①:计算的是整个数组的大小,数组类型为char,所以1×6 = 1
②:arr表示首元素地址,加 0,还是首元素地址,而地址大小为4/8,(X86为4,X64位8
③:*arr为首元素,所以为1
④:arr[1]为第二个元素,所以为1
⑤:arr是首元素地址,取出arr的地址,还是地址,而地址大小为4/8,(X86为4,X64位8
⑥:&arr取出整个数组,加1,跳过整个数组,还是地址,而地址大小为4/8,(X86为4,X64位8
⑦:arr[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,而地址大小为4/8,(X86为4,X64位8

💭解析2

①:arr为首元素地址,strlen要找到 ‘\0’ 才会停下,而字符数组中无 ‘\0’ ,所以为随机值
②:arr为首元素地址,加一还是首元素地址,strlen要找到 ‘\0’ 才会停下,而字符数组中无 ‘\0’ ,所以为随机值
③:*arr为首元素,strlen要找到 ‘\0’ 才会停下,所以会报错
④:arr[1]为第二个元素,strlen要找到 ‘\0’ 才会停下,所以会报错
⑤:arr是首元素地址,取出arr的地址,还是地址,strlen要找到 ‘\0’ 才会停下,而字符数组中无 ‘\0’ ,所以为随机值
⑥:&arr取出整个数组,加1,跳过整个数组,还是地址,strlen要找到 ‘\0’ 才会停下,而字符数组中无 ‘\0’ ,所以为随机值
⑦:arr[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,strlen要找到 ‘\0’ 才会停下,而字符数组中无 ‘\0’ ,所以为随机值

💤答案

在这里插入图片描述

🚩字符串

💦首先我们要知道:strlen求字符串长度,直到遇到**\0结束
💫特例:
1️⃣
sizeof(数组名):表示的是整个数组**
2️⃣&数组名:取出的是整个数组

💤题目

#include <string.h>
#include<stdio.h>
int main()
{
	char arr[] = "abcdef";//[a b c d e f \0]
	printf("%d\n", sizeof(arr));
	printf("%d\n", sizeof(arr + 0));
	printf("%d\n", sizeof(*arr));
	printf("%d\n", sizeof(arr[1]));
	printf("%d\n", sizeof(&arr));
	printf("%d\n", sizeof(&arr + 1));
	printf("%d\n", sizeof(&arr[0] + 1));
	printf("---------------------------------\n");
	
	printf("%d\n", strlen(arr));
	printf("%d\n", strlen(arr + 0));
	//printf("%d\n", strlen(*arr));
	//printf("%d\n", strlen(arr[1]));
	printf("%d\n", strlen(&arr));
	printf("%d\n", strlen(&arr + 1));
	printf("%d\n", strlen(&arr[0] + 1));
	return 0;
}

💤解析

💭解析1

①:sizeof(数组名):表示的是整个数组 ,arr为字符串,所以为7
②:arr表示首元素地址,加 0,还是首元素地址,而地址大小为4/8,(X86为4,X64位8
③:*arr为首元素,所以为 1
④:arr[1]为第二个元素,所以为1
⑤:arr是首元素地址,取出arr的地址,还是地址,而地址大小为4/8,(X86为4,X64位8
⑥:&arr取出整个数组,加1,跳过整个数组,还是地址,而地址大小为4/8,(X86为4,X64位8
⑦:arr[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,而地址大小为4/8,(X86为4,X64位8

💭解析2

①:arr为首元素地址,strlen要找到 ‘\0’ 才会停下,所以为6
②:arr为首元素地址,加一还是首元素地址,strlen要找到 ‘\0’ 才会停下,所以为6
③:*arr为首元素,strlen要找到 ‘\0’ 才会停下,所以会报错
④:arr[1]为第二个元素,strlen要找到 ‘\0’ 才会停下,所以会报错
⑤:arr是首元素地址,取出arr的地址,还是地址,strlen要找到 ‘\0’ 才会停下,所以为 6
⑥:&arr取出整个数组,加1,跳过整个数组,还是地址,strlen要找到 ‘\0’ 才会停下,而字符数组中不知道什么时候找到 ‘\0’ ,所以为随机值
⑦:arr[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,strlen要找到 ‘\0’ 才会停下,为 5

💤答案

在这里插入图片描述

🚩指针

💤题目

#include <string.h>
#include<stdio.h>
int main()
{
	char* p = "abcdef";
	//         012345

	printf("%d\n", sizeof(p));
	printf("%d\n", sizeof(p + 1));
	printf("%d\n", sizeof(*p));
	printf("%d\n", sizeof(p[0]));
	printf("%d\n", sizeof(&p));
	printf("%d\n", sizeof(&p + 1));
	printf("%d\n", sizeof(&p[0] + 1)); 

	printf("----------------------\n");
	printf("%d\n", strlen(p));
	printf("%d\n", strlen(p + 1));
	//printf("%d\n", strlen(*p));//err
	//printf("%d\n", strlen(p[0]));//err
	printf("%d\n", strlen(&p));
	printf("%d\n", strlen(&p + 1));
	printf("%d\n", strlen(&p[0] + 1));
	return 0;
}

💤解析

💭解析1

在这里插入图片描述

①:p 是一个指针变量大小就是4/8
②:p+1是字符串’b’的地址,所以地址大小为4/8
③:p解引用,所以为首元素,所以为 1
④:p[0] == (p+0) ,所以为首元素,所以为 1
⑤:取出的是地址,
*&p == char
***,所以地址大小为4/8
⑥:&p+1跳过指针,指向不知道哪块区域,所以为随机值
⑦:p[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,所以地址大小为4/8

💭解析2

①:p 取出首元素的地址,所以为6
②:p取出首元素地址,加一为第二个元素的地址,所为5
③:*p为首元素,所以异常
④:p[0]为首元素,所以异常
⑤:取出p的地址,但是不指向字符串,所以指向一个未知的空间,所以为随机值
⑥:&p+1跳过指针,指向不知道哪块区域,所以为随机值
⑦:p[0]表示首元素,取地址,表示首元素地址,加1,表示第二个元素地址,所以为 5

💤答案

在这里插入图片描述

🚩二维数组

💤题目

#include <string.h>
#include<stdio.h>
int main()
{
	int a[3][4] = { 0 };

	printf("%d\n", sizeof(a));
	printf("%d\n", sizeof(a[0][0]));
	printf("%d\n", sizeof(a[0]));
	printf("%d\n", sizeof(a[0] + 1));
	printf("%d\n", sizeof(*(a[0] + 1)));
	printf("%d\n", sizeof(a + 1));
	printf("%d\n", sizeof(*(a + 1)));
	printf("%d\n", sizeof(&a[0] + 1));
	printf("%d\n", sizeof(*(&a[0] + 1)));
	printf("%d\n", sizeof(*a));
	printf("%d\n", sizeof(a[3]));

	return 0;
}

💤解析

💫特例:
1️⃣sizeof(数组名):表示的是整个数组
2️⃣&数组名:取出的是整个数组
在这里插入图片描述
①:sizeof(a),表示的是整个数组,所以为344 = 48
②:a[0][0]为第一行第一列第一个元素,所以为 4
③:a[0]为第一行大小 416
④:第一行第二个元素的地址,地址大小为 4/8
⑤:第一行第二个元素的地址,再解引用,所以为第一行第二个元素的大小,所以为 4
⑥:a是数组首元素地址,+1,第二行的地址,地址大小为 4/8
⑦:
(a+1) == a[1],所以计算的是第二行的大小,所以为 4*4
⑧:&a[0]为第一行地址,&a[0]+1第二行的地址,地址大小为 4/8
⑨:&a[0]为第一行地址,&a[0]+1第二行的地址,解引用,为第二行元素大小 4 * 4
⑩:*a–> (a+0) --> a[0] ,所以为4 * 4
11:这a[3]越界,但是还是int a[4] 所以为 4
4

💤答案

在这里插入图片描述

指针笔试题

1️⃣

💤题目

#include<stdio.h>

int main()
{
	int a[5] = { 1, 2, 3, 4, 5 };
	int* ptr = (int*)(&a + 1);
	printf("%d,%d", *(a + 1), *(ptr - 1));
	return 0;
}

💤解析/答案

在这里插入图片描述

💭(a + 1)指向第二元素地址,解引用 * 取出第二个元素,所以为 2
💭ptr指向跳过数组后面的位置,(ptr - 1),向后退一个元素,所以为5
在这里插入图片描述

2️⃣

💤题目

#include<stdio.h>
//这里告知结构体的大小是20个字节(到后期会详细介绍)
struct Test
{
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];
}* p = (struct Test*)0x100000;

//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned long)p + 0x1);
	printf("%p\n", (unsigned int*)p + 0x1);
	return 0;
}

💤解析/答案

💭博主使用的编译器为小端存储(采用不同的存储方式,结果也不一样)
💭0x1为十六进制,为0x000001,** p + 1,所以跳过一个结构体(20字节)而20在十六进制中为0x000014,所以0x100000 + 0x000014=0x100014
💭
unsigned long是无符号整数,(unsigned long)p整形提升(unsigned long)p = 0x100000**,所以0x100000+0x000001=0x100004
💭unsigned int无符号整数,解引用 * ,(unsigned int * )p + 0x1 = (unsigned int * )p + 1,解释为:无符号整数类型为int,加一跳过4(int)个字节
在这里插入图片描述

3️⃣

💤题目

#include<stdio.h>
int main()
{
	int a[4] = { 1, 2, 3, 4 };
	int* ptr1 = (int*)(&a + 1);
	int* ptr2 = (int*)((int)a + 1);
	printf("%x,%x", ptr1[-1], *ptr2);
	return 0;
}

💤解析/答案

在这里插入图片描述

💭&a取出整个数组,加一跳过整个数组,(int*)类型,指向 ptr1,而ptr1[-1] =ptr1 - 1,因此向前移动一个元素,指向4这个元素。
💭a取出首元素地址,转为(int)类型,加一跳过一个字节,用(int*)接收,指向ptr2,*ptr2解引用,指向 00,取出四个字节,所以为 00 00 00 02,以小端存储,所以为 20 00 00 00
在这里插入图片描述

4️⃣

💤题目

#include <stdio.h>
int main()
{
	int a[3][2] = { (0, 1), (2, 3), (4, 5) };
	int* p;
	p = a[0];
	printf("%d", p[0]);
	return 0;
}

💤解析/答案

在这里插入图片描述
在这里插入图片描述

5️⃣

💤题目

#include <stdio.h>
int main()
{
	int a[5][5];
	int(*p)[4];
	p = a;
	printf("%p, %d\n", 
		&p[4][2] - &a[4][2], 
		&p[4][2] - &a[4][2]);
	return 0;
}

💤解析/答案

在这里插入图片描述
在这里插入图片描述

6️⃣

💤题目

#include <stdio.h>
int main()
{
	int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
	int* ptr1 = (int*)(&aa + 1);
	int* ptr2 = (int*)(*(aa + 1));
	printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));
	return 0;
}

💤解析/答案

💭正所谓师傅领进门,修行靠个人,这题与前面太想相似了,不多说了😎
在这里插入图片描述

7️⃣

💤题目

#include <stdio.h>
int main()
{
	char* a[] = { "work","at","alibaba" };
	char** pa = a;
	pa++;
	printf("%s\n", *pa);
	return 0;
}

💤解析/答案

💭正所谓师傅领进门,修行靠个人,这题与前面太想相似了,不多说了😎
在这里插入图片描述

8️⃣

💤题目

#include <stdio.h>
int main()
{
	char* c[] = { "ENTER","NEW","POINT","FIRST" };
	char** cp[] = { c + 3,c + 2,c + 1,c };
	char*** cpp = cp;

	printf("%s\n", **++cpp);
	printf("%s\n", *-- * ++cpp + 3);
	printf("%s\n", *cpp[-2] + 3);
	printf("%s\n", cpp[-1][-1] + 1);
	return 0;
}

💤解析/答案

🗯️这里要明白,一旦指针改变方向和取向,再使用的话,只能用指针改变后的
在这里插入图片描述
在这里插入图片描述

💤结束语🎉🎉🎉

今天内容就到这里啦,时间过得很快,大家沉下心来好好学习,会有一定的收获的,大家多多坚持,嘻嘻,成功路上注定孤独,因为坚持的人不多。那请大家举起自己的小说给博主一键三连,有你们的支持是我最大的动力💞💞💞,回见。
在这里插入图片描述

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

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

相关文章

华为数通智选交换机S5735S-L24T4S-QA2无法SSH远程访问

以前都是按照华为S5700交换机开启SSH远程访问方法配置不同网段通过静态路由实现互通,华为S5700交换机开启ssh远程登陆,现在新买的华为数通智选交换机S5735S-L24T4S-QA2,也是按照这步骤配置,令人不解的是,竟然无法ssh访问,仔细看了配置也没有发现问题,在华为eNSP模拟器上验…

【UniApp开发小程序】顶部导航栏和底部导航栏设置+iconfont图标引入

文章目录 顶部导航栏和底部导航栏设置创建几个需要底部导航栏切换的页面使用阿里巴巴矢量图标库完成底部导航栏tabBar设置页面顶部导航栏标题 样式优化 顶部导航栏和底部导航栏设置 在正式开发小程序的功能之前&#xff0c;首先需要确定小程序的主要框架。 创建几个需要底部导…

通讯录(纯C语言实现)

相信大家都有过通讯录&#xff0c;今天我来带大家实现以下最简单的通讯录&#xff0c;通过本篇文章&#xff0c;相信可以让大家对C语言有进一步的认识。 话不多说&#xff0c;我们先放函数的实现 #define _CRT_SECURE_NO_WARNINGS 1 #include "Contact.h"int Chea…

Nautilus Chain 更换全新测试网,主网即将在不久上线

目前&#xff0c;Nautilus Chain 正在为主网上线前的最后阶段做准备&#xff0c;据悉该链更新了全新的测试网&#xff0c;在此前版本的测试网的基础上进行了全新的技术升级&#xff0c;最新测试网版本与生态发展的技术规划更为贴近。本次测试网升级将会是最后一次测试网版本的迭…

基于深度学习的高精度80类动物目标检测系统(PyTorch+Pyside6+YOLOv5模型)

摘要&#xff1a;基于深度学习的高精度80类动物目标检测识别系统可用于日常生活中或野外来检测与定位80类动物目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的80类动物目标检测识别&#xff0c;另外支持结果可视化与图片或视频检测结果的导出。本系统采用YO…

Ubuntu下配置Redis哨兵集群

目录 准备实例和配置 启动哨兵集群 测试配置 搭建一个三节点形成的Sentinel集群&#xff0c;来监管Redis主从集群。 三个sentinel哨兵实例信息如下&#xff1a; 节点IPPORTs1192.168.22.13527001s2192.168.22.13527002s3192.168.22.13527003 准备实例和配置 要在同一台虚…

week2

第2周 目录 第2周 四、多变量线性回归(Linear Regression with Multiple Variables) 4.1 多维特征4.2 多变量梯度下降4.3 梯度下降法实践1-特征缩放4.4 梯度下降法实践2-学习率4.5 特征和多项式回归4.6 正规方程4.7 正规方程及不可逆性(可选) 四、多变量线性回归(Linear Regres…

opencv 基础图像操作-彩色图像

opencv 基础图像操作-彩色图像 彩色图像 相比二值图像和灰度图像&#xff0c;彩色图像是更常见的一类图像&#xff0c;它能表现更丰富的细节信息。 神经生理学实验发现&#xff0c;在视网膜上存在三种不同的颜色感受器&#xff0c;能够感受三种不同的颜色&#xff1a;红色、绿色…

SpringBoot【原理分析、YAML文件、SpringBoot注册web组件】(二)-全面详解(学习总结---从入门到深化)

目录 SpringBoot原理分析_核心注解 YAML文件_配置文件介绍 YAML文件_自定义配置简单数据 YAML文件_自定义配置对象数据 YAML文件_自定义配置集合数据 YAML文件_读取配置文件的数据 使用ConfigurationProperties读取 YAML文件_占位符的使用 YAML文件_配置文件存放位置及优…

python调用钉钉发送告警消息

zabbix和prometheus都能做监控告警调用企业微信和钉钉。那么问题来了做为一名合格的运维和开发人员&#xff0c;脚本发现故障告警&#xff0c;自动调用发送详细告警内容&#xff0c;这点儿东西得会。 效果图如下&#xff1a; 普通发送方式 import requestsdef dingding_info(…

学习系统编程No.30【多线程控制实战】

引言&#xff1a; 北京时间&#xff1a;2023/7/7/9:58&#xff0c;耳机正在充电中&#xff0c;所以刚好让我们先把引言写一写&#xff0c;昨天睡觉前听了一会小说&#xff0c;听小说的好处就在于&#xff0c;它可以让你放下手机&#xff0c;快速睡觉&#xff0c;并且还有一定的…

【DBA课程-笔记】第2章:MongoDB数据数据查询与分析

目录 一、课程大纲 二、MongoDB 条件查询 1. 制造 MongoDB 测试数据 2. MongoDB 数据查询 与 SQL对应关系 3. MongoDB 查询运算符 4. MongoDB 数据查询、条件查询、过滤 5. MongoDB 条件查询命令 6. MongoDB 数据查询数组条件 A. 精确匹配数组元素&#xff1a; B. 无…

检测到错误页面web应用服务器版本信息泄露

详细描述 Web服务器未能正确处理异常请求导致Web服务器版本信息泄露&#xff0c;攻击者收集到服务器信息后可进行进一步针对性攻击。 解决办法 临时修复建议如下&#xff1a; 1、关闭web服务器错误提示。 2、关闭运行平台的错误提示。 3、建立错误机制&#xff0c;不要把真实…

校园课表微信小程序全栈项目

遇到的第一个问题关于npm start 首先找到对应的后端项目 crtl shift (esc键下的波浪号) 召唤终端 Error:Cannot find module dotenv 解决问题: npm install dotenv 简写 npm i dotenv 然后遇到第二个问题 Port 3000 is already in use 我的3000接口被占用 那就要去检…

leetcode 74. 搜索二维矩阵(java)

搜索二维矩阵 leetcode 74. 搜索二维矩阵题目描述抽象BST代码演示 抽象BST leetcode 74. 搜索二维矩阵 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;https://leetcode.cn/problems/search-a-2d-matrix 题目描述 给你一个满足下述两条属性的 m x n 整…

uniapp和uview组件实现下拉触底刷新列表

下面是一个在UniApp中使用uView组件实现下拉触底刷新列表的示例&#xff0c;并使用Axios来请求分页数据列表&#xff1a; 首先&#xff0c;确保你已经在UniApp项目中添加了uView组件库。你可以在项目根目录执行以下命令安装它们&#xff1a; npm install uview-ui或者使用 Hb…

【Vue3】setup参数细讲!computed计算属性和watch监听属性

setup参数细讲&#xff01;computed计算属性和watch监听属性 setup细讲!setup参数&#xff0c;steup&#xff08;props&#xff0c;context&#xff09;参数1.props&#xff0c;负责接收父组件传过来的值参数2.contextcontext.attrscontext.emitcontext.slots&#xff0c; 插槽…

CSS 伪元素: ::marker 自定义列表序号

::marker 伪元素 ::marker&#xff0c;可作用在任何设置了 display: list-item 的元素或伪元素上&#xff0c;例如<li>和<summary>。 /** <ul><li>Peaches</li><li>Apples</li><li>Plums</li> </ul> */ ul li::…

Java 设计模式——迭代器模式

目录 1.概述2.结构3.案例实现3.1.抽象迭代器3.2.具体迭代器3.3.抽象聚合3.4.具体聚合3.5.测试 4.优缺点5.使用场景6.JDK 源码解析——Iterator 1.概述 迭代器模式 (Iterator Pattern) 是一种行为型设计模式&#xff0c;它提供一种顺序访问聚合对象&#xff08;如列表、集合等&…

Hyperledger Fabric测试网络运行官方Java链码[简约版]

文章目录 启动测试网络使用peer CLI测试链码调用链码 启动测试网络 cd fabric-samples/test-networknetwork.sh的脚本语法是&#xff1a;network.sh <mode> [flag] ./network.sh up./network.sh createChannel在java源码路径下 chmod 744 gradlew vim gradlew :set ffu…