当前位置: 首页 > article >正文

数组和指针常见笔试题(深度剖析)

strlen和sizeof的区别

strlen是统计\0之前的字符个数,传递的是地址

sizeof是计算类型的字节数,其实在编译期间会通过类型来确定大小

下边我来讲一下常见的面试题,过程很详细放心观看

#include<stdio.h>

#include <string.h>

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

	printf("%d\n", strlen(arr));//随机值,因为strlen是遇到斜杠\0结束,统计\0之前的字符个数
	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));//随机值

	printf("%d\n", sizeof(arr));//sizeof统计的是字节大小(包括\0),记住数组名放在sizeof内部表示数组全部元素大小,所以是6
	printf("%d\n", sizeof(arr + 0));//arr+0和数组名arr不是一个意思,所以表示的是地址,4/8
	printf("%d\n", sizeof(*arr));//数组首元素地址解引用之后是数组首元素,1字节
	printf("%d\n", sizeof(arr[1]));//元素b,1字节
	printf("%d\n", sizeof(&arr));//整个数组的地址也是地址,4/8
	printf("%d\n", sizeof(&arr + 1));//跳过一个数组大小,还是地址4/8
	printf("%d\n", sizeof(&arr[0] + 1));//第二个元素的地址,注意[]优先级比&高

	return 0;
}

 

#include<string.h>
int main()
{
	char arr[] = "abcdef";//这种就是数组结尾多了一个\0,本质还是数组

	printf("%d\n", strlen(arr));//6,统计\0之前的字符个数
	printf("%d\n", strlen(arr + 0));//还是6,起始地址是数组首元素地址
	//printf("%d\n", strlen(*arr));//err 不能放元素
	//printf("%d\n", strlen(arr[1]));//err t同理
	printf("%d\n", strlen(&arr));//还是6,因为数组的地址和数组首元素的地址相同,直接统计\0之前的字符个数
	printf("%d\n", strlen(&arr + 1));//随机值,跳过一个数组的地址,相当于后边是随机值
	printf("%d\n", strlen(&arr[0] + 1));//第二个元素的地址,5


	printf("%d\n", sizeof(arr));//7,统计字符个数+\0

	printf("%d\n", sizeof(arr + 0));//数组首元素地址,地址大小是4/8(32位或者64位机器的区别)
	printf("%d\n", sizeof(*arr));//数组首元素的地址被解引用,是数组首元素,1

	printf("%d\n", sizeof(arr[1]));//数组第二个元素,1
	printf("%d\n", sizeof(&arr));//数组的地址,大小是4/8
	printf("%d\n", sizeof(&arr + 1));//还是地址
	printf("%d\n", sizeof(&arr[0] + 1));//数组第二个元素的地址


	return 0;
}

本节的内容基础之前写过,我把链接放在综这里有需要的可以看看,比如数组名那里就可以回顾一下指针的进阶_在指针中int*w,*p=*w是-CSDN博客文章浏览阅读1.7k次,点赞33次,收藏39次。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。1. sizeof(数组名),这里的数组名不是数组首元素的地址,数组名表示整个数组,sizeof(数组名)计算的是整个数组的大小,单位是字节。数组名是数组首元素的地址,arr[1]拿到的是arr1数组名,再使用下标就能访问数组的元素,很简单。2. &数组名,这里的数组名表示整个数组, &数组名取出的是整个数组的地址。是指针,指针指向的是一个函数,指向的函数无参数,返回值类型为void。_在指针中int*w,*p=*w是 https://blog.csdn.net/eixjdj/article/details/145118231

#include<stdio.h>
#include<string.h>
int main()
{
	const char* p = "abcdef";//字符串结尾有\0


	printf("%d\n", strlen(p));//6,统计\0之前的
	printf("%d\n", strlen(p + 1));//5,从第二个地址开始
   // printf("%d\n", strlen(*p));//err,不能放非地址
	//printf("%d\n", strlen(p[0]));//err 和上边同理
	printf("%d\n", strlen(&p));//相当于是字符串首地址的地址,p指向一个地址,不确定什么时候遇到\0,是随机值
	printf("%d\n", strlen(&p + 1));//跳过整个数组的地址,随机值
	printf("%d\n", strlen(&p[0] + 1));//第二个元素的地址,5

	printf("%d\n", sizeof(p));//地址大小是4/8
	printf("%d\n", sizeof(p + 1));//第二个位置的指针,4/8
	printf("%d\n", sizeof(*p));//第1个元素,刚才讲过是1
	printf("%d\n", sizeof(p[0]));//第一个元素,1
	printf("%d\n", sizeof(&p));//地址大小是4或8
	printf("%d\n", sizeof(&p + 1));//地址大小是4或8
	printf("%d\n", sizeof(&p[0] + 1));//地址大小是4或8

	return 0;
}

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

	printf("%d\n", sizeof(a));//sizeof数组名是整个数组大小,所以是3*4*4=48
	printf("%d\n", sizeof(a[0][0]));//这个是经典的二维数组的第一个元素,大小是一个整形4
	printf("%d\n", sizeof(a[0]));//是第一行数组的数组名,数组名放在sizeof是整个数组大小,所以是第一行的大小是4*4=16
	printf("%d\n", sizeof(a[0] + 1));//第一行数组的首元素的地址+1跳过一个整形,是第一行第二个元素的地址,4/8
	printf("%d\n", sizeof(*(a[0] + 1)));//解引用第一行第二个元素的地址,拿到这个元素,4
	printf("%d\n", sizeof(a + 1));//二维数组的数组名也是数组首元素的地址,二维数组的多行一维数组可以看成多个元素
	//那么可以理解为第一个元素的地址也就是第一行的地址,第一行的地址+1跳过这一行到第二行,成为第二行的地址,数组的地址是4/8
	printf("%d\n", sizeof(*(a + 1)));//第二行的地址被解引用,是第二行的所有元素也就是16
	printf("%d\n", sizeof(&a[0] + 1));//a[0]是第一行数组名,取地址是第一行数组的地址,+1是跳过第一行元素,成为第二行元素的地址,4/8
	printf("%d\n", sizeof(*(&a[0] + 1)));//对第二行数组地址解引用,拿到第二行的数组元素是16
	printf("%d\n", sizeof(*a));//a是数组首元素的地址,第一行的地址,解引用拿到这一行是16
	printf("%d\n", sizeof(a[3]));//这里不会越界访问,因为sizeof是在编译时查看括号内的类型而确定大小,并不会运算,所以还是16

	return 0;
}

以上就是对常见笔试题的剖析,感谢一直以来支持我的人!!

 

 

 

 

 


http://www.kler.cn/a/553649.html

相关文章:

  • Centos7 使用 yum 报错 Could not retrieve mirrorlist
  • 【Rust中级教程】1.10. 引用及内部可变性(简单回顾):引用、内部可变性、`Cell`类型及相关操作
  • less 和 sass 的异同(css 预处理语言)
  • 非docker安装open-webui连接ollama实现deepseek本地使用,集成其他openai模型,常见启动报错问题解决。
  • 人工智能丨卷积神经网络的概念, 它与普通的神经网络有何不同
  • HarmonyOS的核心特性:分布式技术引领创新
  • DeepSeek与ChatGPT:会取代搜索引擎和人工客服的人工智能革命
  • Zookeeper(54)如何使用Zookeeper的命令行工具?
  • Redis-03高级篇下-最佳实践:
  • Nginx下proxy_redirect的三种配置方式
  • scroll、offset、client三大家族和getBoundingClientRect方法
  • android 定制mtp连接外设的设备名称
  • 基于JavaSpringboot+Vue实现前后端分离房屋租赁系统
  • lua的local 变量和self 变量的理解理解后解决自己写的bug.
  • 【论文阅读】DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning
  • git-提交时间和作者时间的区别
  • 当使用vcpkg安装的qt5时,在VS调用出现libcrypto-*-x64.dll不是有效路径时
  • Docker如何切换文件目录安装——详细攻略!
  • IOS UITextField 无法隐藏键盘问题
  • 苹果新品今日发布,AI手机市场竞争加剧,近屿智能专注AI人才培养