18. 《C语言》——【Nice2016年校招笔试题引发的思考】

news2024/7/4 4:40:57

在这里插入图片描述


亲爱的读者,大家好!我是一名正在学习编程的高校生。在这个博客里,我将和大家一起探讨编程技巧、分享实用工具,并交流学习心得。希望通过我的博客,你能学到有用的知识,提高自己的技能,成为一名优秀的程序员。如果你有任何疑问或建议,请随时在评论区留言,让我们一起成长进步!现在,让我们开始这场知识之旅吧!


在这里插入图片描述

🏞️个人主页: FEN03
📊收入专栏: C语言

🌻🌼🌷🪻🌹🌷🌼🌻🌺🌹🪻🌼🌻🌺🌷🪻🌹🌷🌼🌻🌺🌻🌷🪻🌹🪻🌷🌼🌻🌻🌺🌼🌷🪻🌹🪻🌷


🎄文章目录

  • 🦊 前言 🍖
  • 🫎 Nice2016年校招笔试题 🥩
  • 🦦相同类型题目🥓
  • 👋🏻结束语🌹


🦊 前言 🍖

今天,有位朋友给我看了这道题,发现与Nice在2016年校招笔试题中的一道题是类似的,那么就让我们一起来探讨吧~ ⬇️⬇️⬇️


🫎 Nice2016年校招笔试题 🥩


下边代码为Nice在2016年校招笔试题中的其中一道,让我们来一起看看吧😃😃

要求是在LInux X86_64 gcc环境下,下面的程序会出现什么问题?运行结果是什么?为什么?

#include<stdio.h>
int main(int argc, char* argv[])
{
	long i;
	long a[16];
	for (i = 0; i <= 17; i++)
	{
		a[i] = 0;
		printf("%d ", i);   
	}
	return 0;
}

当我看到这一道题目时,我就想起来有一道与它相似的,这道题目最早是出自于《C语言陷阱与缺陷》,那么接下来就让我们一起看看吧~ 🌹


🦦相同类型题目🥓


那么我在VS2022中,X86,Debug的环境下,并且编译器不做任何的优化,下面的代码会执行什么样的结果呢❓❓❓

#include <stdio.h>
int main()
{
	int i = 0;
	int arr[10] = {1,2,3,4,5,6,7,8,9,10};
	for (i = 0; i <= 12; i++)
	{
		arr[i] = 0;
		printf("Nice\n");
	}
	return 0;
}

运行结果…

在这里插入图片描述

我们看到,程序运行结果,是死循环了,那么为什么会这样呢?

让我们调式观察吧⬇️⬇️⬇️

  1. 我们可以看到已经调式起来,并且可以在监视窗口看到i和arr的值
    在这里插入图片描述
  2. 下一步,到了for循环,for遍历数组,把数组的全部下标都改为了0,那么这时候数组还没有越界访问, 但是,for循环并没有到此结束,当我们继续会发生什么呢?
    在这里插入图片描述
  3. 当我继续时,这时候已经是越界访问了,并且把arr[10],arr[11],也改成了0,但是这时的for循环还没有结束,那么我再继续会发生什么❓❓❓
    在这里插入图片描述
  4. 那么我再继续,也就是最后一次for循环了
    在这里插入图片描述
    看下面动图,我进行最后一次for循环,arr[12]也是改为了0,突然 i 变量变为了0,并且与arr[12]的值是一样的了,这是为什么❓难道它们的地址是一样的吗❓
    在这里插入图片描述
  5. 当我把arr[12]与 i 的地址打开看看,可以发现它们的地址是一模一样的。
    在这里插入图片描述
    为了更为详细的解释,我们通过画图的方式进行讲解⬇️⬇️⬇️

分析:

  1. 首先整型变量i和整型数组arr,它们都是局部变量,那么局部变量是存放在栈区的,而栈区上内存的使用习惯是先使用高地址的空间再使用低地址的空间
  2. 那我们知道,栈区是存放局部变量和形式参数;堆区是存放动态内存开辟,如malloc,calloc,realloc,free;静态区是存放全局变量和由static修饰的静态变量。
  3. 我们可以把上面代码中它们在栈区的内存布局画出来
    我们通过该图,可以看到代码在栈区的内存布局,前边我们解释了,栈区是先使用高地址再使用低地址,我们按照创建变量的先后,分别把它们在内存布局画了出来,数组的地址是连续存放的并且是由低地址到高地址,
    那么通过不断的遍历数组,当arr[9]改为0时,这时候并没有越界访问,但是遍历还没结束,再次进行,arr[10],arr[11]都被改为了0,这已经是越界访问了,当再一次越界访问,看下图,这时arr[12]访问到了i 。所以,i 与 arr[12] 的地址是相同,既然地址相同,那么它们的值都是一样的,所以当i不断的++,arr[12]的值也跟着++,当arr[12] = 0 时,i也变为了0,最终不断的死循环。那么大家可能会有所疑惑,有这么巧吗❓
    在这里插入图片描述
  4. 我们看到 i 和 arr 中间空了2个int,其实这并不是巧合,至于它们中间空多大,取决于编译器的实现,在vc6.0中,相同的代码,i 和 arr 之间没有空隙;在gcc 中,i 和 arr 之间空1个int;在vs中空2个int 。

👋🏻结束语🌹


非常感谢您花时间阅读我的博客,希望我的分享能为您带来收获。如果您对本文有任何想法或疑问,欢迎在评论区留言交流。如果您喜欢我的博客,请继续关注,我会定期更新更多精彩内容。最后,别忘了行动起来的力量,让我们一起实践这些方法,见证自己的成长和进步!

再见,祝您生活愉快!


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

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

相关文章

证明 泊松分布 的期望和方差

泊松分布 泊松分布&#xff08;Poisson Distribution&#xff09;是描述在固定时间间隔内某事件发生次数的概率分布&#xff0c;特别适用于稀有事件的统计。假设随机变量 ( X ) 表示在时间间隔 ( t ) 内某事件发生的次数&#xff0c;并且该事件在单位时间内发生的平均次数为 (…

牛客练习题打卡(06-15)

run方法线程执行体 .start方法开启多线程 在java中 &#xff0c; 整数类型默认int,带小数默认double ; 如果要指定长整型加L&#xff1b;如果要指定为单精度加F ; 在java中&#xff0c;重载要求方法名相同&#xff0c; 参数列表必须不同&#xff08;个数不同、或类型不同、参数…

Oracle数据库Day03-单行函数

1. 单行函数 处理数据项接受函数并返回一个值对返回的每一行采取行动每行返回一个结果可能会修改数据类型可以嵌套接受可以是列或表达式的参数 function_name[(arg1, arg2,…)]

【面试干货】Class.forName()与ClassLoader.loadClass()在Java反射中的区别

【面试干货】Class.forName&#xff08;&#xff09;与ClassLoader.loadClass&#xff08;&#xff09; 在Java反射中的区别 1、Class.forName()1.1 示例代码1.2 关键点 2、ClassLoader.loadClass()2.1 示例代码2.2 关键点 3、两者之间的区别 &#x1f496;The Begin&#x1f…

主流框架选择:React、Angular、Vue的详细比较

目前前端小伙伴经常使用三种广泛使用的开发框架&#xff1a;React、Angular、Vue - 来设计网站 Reactjs&#xff1a;效率和多功能性而闻名 Angularjs&#xff1a;创建复杂的应用程序提供了完整的解决方案&#xff0c;紧凑且易于使用的框架 Vuejs&#xff1a;注重灵活性和可重用…

解决老毛子路由器自带微信提示功能无法触发问题

新买了一个二手的RM AC2100&#xff0c;刷了老毛子后&#xff0c;发现自带的上下线微信提示无法使用(方糖公众号无信息) 经我开启SSH&#xff0c;将上下线部分代码拿出来调试发现&#xff0c;发不出来的原因是原版信息发送长度过长&#xff0c;需要截取一部分才能发送成功。 …

查看npm版本异常,更新nvm版本解决问题

首先说说遇见的问题&#xff0c;基本上把nvm&#xff0c;npm的坑都排了一遍 nvm版本导致npm install报错 Unexpected token ‘.‘install和查看node版本都正确&#xff0c;结果查看npm版本时候报错 首先就是降低node版本… 可以说基本没用&#xff0c;如果要降低版本的话&…

比亚迪智驾技术震撼登场!L3级自动驾驶领跑全国,无图导航、夜间挑战轻松应对!

作为新能源汽车领域的翘楚&#xff0c;比亚迪在电池技术与智能驾驶方面都有着卓越的表现。近日&#xff0c;比亚迪凭借其领先的智驾技术&#xff0c;成功入选全国首批L3级自动驾驶上路及行驶试点名单&#xff0c;这无疑将推动智驾技术的普及速度。 你知道吗&#xff1f;比亚迪智…

Unity中的伽马(Gamma)空间和线性(Linear)空间

伽马空间定义&#xff1a;通常用于描述图像在存储和显示时的颜色空间。在伽马空间中&#xff0c;图像的保存通常经过伽马转换&#xff0c;使图片看起来更亮。 gamma并不是色彩空间&#xff0c;它其实只是如何对色彩进行采样的一种方式 为什么需要Gamma&#xff1a; 在游戏业…

并发容器(二):Concurrent类下的ConcurrentHashMap源码级解析

并发容器-ConcurrentHashMap 前言数据结构JDK1.7版本HashEntrySegment 初始化 重要方法Put方法扩容rehash方法 前言 之前我们在集合篇里聊完了HashMap和HashTable&#xff0c;我们又学习了并发编程的基本内容&#xff0c;现在我们来聊一聊Concurrent类下的重要容器&#xff0c…

程序设计实践--字符串

字符串 回文串 “回文”是指正读反读都能一样的句子,它是古今中外都有的一种修辞方式和文字游戏。你的任务是从键盘输入一个字符串(最大长度<100),判断这个字符串是不是回文,如果是回文,则输出“Yes”, 如果不是, 则输出“No”。 输入描述 输入若干个字符串(最大长…

[C++]使用yolov10的onnx模型结合onnxruntime和bytetrack实现目标追踪

【官方框架地址】 yolov10yolov10框架&#xff1a;https://github.com/THU-MIG/yolov10 bytetrack框架&#xff1a;https://github.com/ifzhang/ByteTrack 【算法介绍】 Yolov10与ByTetrack&#xff1a;目标追踪的强大组合 Yolov10和ByTetrack是两种在目标追踪领域具有显…

【计算机组成原理】指令系统考研真题详解之拓展操作码!

计算机组成原理&#xff1a;指令系统概述与深入解析 1. 指令系统概述 计算机软硬件界面的概念 在计算机组成原理中&#xff0c;指令系统扮演着至关重要的角色&#xff0c;它是计算机软硬件界面的核心。软件通过指令与硬件进行通信&#xff0c;硬件根据指令执行相应的操作。指…

韩顺平0基础学java——第24天

p484-508 System类 常见方法 System.arrycopy&#xff08;src&#xff0c;0&#xff0c;dest&#xff0c;1,2&#xff09;&#xff1b; 表示从scr的第0个位置拷贝2个&#xff0c;放到目标数组索引为1的地方。 BigInteger和BigDecimal类 保存大整数和高精度浮点数 BigInte…

Unity的三种Update方法

1、FixedUpdate 物理作用——处理物理引擎相关的计算和刚体的移动 (1) 调用时机&#xff1a;在固定的时间间隔内&#xff0c;而不是每一帧被调用 (2) 作用&#xff1a;用于处理物理引擎的计算&#xff0c;例如刚体的移动和碰撞检测 (3) 特点&#xff1a;能更准确地处理物理…

RIP路由附加度量值(华为)

#交换设备 RIP路由附加度量值 RIP&#xff08;Routing Information Protocol&#xff09;路由协议中的附加度量值是指在RIP路由原来度量值的基础上所增加的额外度量值&#xff0c;通常以跳数来表示。这个附加度量值可以是正值&#xff0c;也可以是负值&#xff0c;用于影响路…

嵌入式学习记录6.14(练习)

#include "mainwindow.h" #include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);this->resize(1028,783); //设置左侧背景QLabel *lab1new QLabel(this);lab1->…

慈善组织管理系统设计

一、用户角色与权限 慈善组织管理系统设计首先需要考虑的是用户角色与权限的划分。系统应明确区分不同的用户角色&#xff0c;如管理员、项目负责人、财务人员、捐赠者等&#xff0c;并为每个角色分配相应的权限。管理员应拥有最高的权限&#xff0c;能够管理系统全局&#xf…

集成学习方法:Bagging与Boosting的应用与优势

个人名片 &#x1f393;作者简介&#xff1a;java领域优质创作者 &#x1f310;个人主页&#xff1a;码农阿豪 &#x1f4de;工作室&#xff1a;新空间代码工作室&#xff08;提供各种软件服务&#xff09; &#x1f48c;个人邮箱&#xff1a;[2435024119qq.com] &#x1f4f1…

嵌入式数据库的一般架构

嵌入式数据库的架构与应用对象紧密相关&#xff0c;其架构是以内存、文件和网络等三种方式为主。 1.基于内存的数据库系统 基于内存的数据库系统中比较典型的产品是每个McObject公司的eXtremeDB嵌入式数据库&#xff0c;2013年3月推出5.0版&#xff0c;它采用内存数据结构&…