【C语言深度剖析——第一节(关键字1)】《C语言深度解剖》+蛋哥分析+个人理解

你未曾见过火光,难怪甘愿漂泊寒夜
本文由@睡觉待开机原创,未经允许不得转载。
本内容在csdn网站首发
欢迎各位点赞—评论—收藏
如果存在不足之处请评论留言,共同进步!

首先简单介绍一下《C语言深度解剖》:

在这里插入图片描述

全书特点:

主要讲了C语言中的大部分重点内容。
这是一本市面上比较小众的书籍,篇幅简短却涵盖了C语言中大部分的重点内容,讲的比较深入。缺点也有哈,就是里面有部分错误,并且部分内容讲的很突兀,感觉前后连贯性比较差。

适合人群:

《C语言深度解剖》是一本很好的C语言进阶书籍,建议对C语言有一些了解的人群进行阅读。

获取渠道:

这本书目前纸质版市面上是没有的,电子版作者是免费提供的,可以自己去网上找资源。当然,有同学想要看这本书的话可以私信我免费分享给你。

本系列博客介绍

下面就开始正题切入了,本系列博客是对本书+蛋哥分析+自我理解的笔记博客,有下面一些优点:
1.补充了一些C语言相关内容:为了弥补全书内容少部分内容的问题,有些重点没有,所以做了一些补充。
2.进行了明确的详细的分析:本书重点虽然明确,但是因为本书讲的有些难懂,因而本博客里直接明确出来。
3.找出并修改所有错误:本书中存在一些错误和不准确的地方,本系列博客将错误陈述明确并且改正。

本系列博客的讲述形式不是完全按照书本的顺序,而是作者我按照自认为的重点并结合书的顺序重新进行了排版和规划,删改了原书中的部分内容,并加以分析说明。旨在取其精华而去其糟粕。

本节博客内容简介

本节博客主要是围绕关键字这一主题进行分析与解释,本节会有一些关键字相关的衍生概念与定义,了解了本节内容之后,会对C语言的掌握有一个很大的提升。

1.第一个C程序(程序启动的本质及其大概原因)

这个其实就是我们刚开始学习C语言时候学习的第一个C语言程序,问好世界

#include<stdio.h>//预处理

int main()
{

	printf("hellow world!\n");

	return 0;
}

//运行程序的方式,可以直接在vs当中ctrl+f5启动
//也可以在vs中生成二进制可执行程序执行程序,双击运行
//所以,我们需要明确一件事情:我们是负责写程序的人,而编译器是把我们写的文本文件编译链接成为二进制可执行程序

//运行程序的方式,可以直接在vs当中ctrl+f5启动
//也可以在vs中生成二进制可执行程序执行程序,双击运行
在这里插入图片描述
上面就是vs帮我们生成的二进制可执行程序,双击即可执行。
//所以,我们需要明确一件事情:我们是负责写程序的人,而编译器是把我们写的文本文件编译链接成为二进制可执行程序,也就是说,文本程序->(经过编译和链接)->二进制可执行程序。
在这里,我想说的其实是我们启动运行程序的本质是什么?
我们启动程序的本质就是把程序数据加载到内存当中,让计算机进行计算并运行(换言之,任何程序在运行前都需要被加载到内存当中)。
为什么启动程序需要把数据加载到内存当中?在这里大体给大家解释一下(下图为数据在计算机各部分的逻辑图)原因在于快!
在这里插入图片描述
在解释之前,首先科普一下计算机硬件的一个常识,计算机的cpu中的寄存器单价最贵效率最高,内存单价较贵效率较高,硬盘单价便宜,效率低。
在这里插入图片描述

原因在于程序原本不用的时候是存储在计算机硬盘当中的,为了快速读取程序,计算机先把程序放到内存当中,之后进一步使电脑cpu对内存中的程序数据进行读取,之所以不会让cpu直接去硬盘中读取数据,在于去硬盘读取数据很慢,而在内存中读取数据比较快捷。
注:至于为什么运行程序需要加载到内存中的具体原因,请看后续内容

2.变量的定义与声明

变量的定义是什么?

所谓定义,本质上就是在内存中开辟特定大小的空间。

怎么进行变量定义?

int x = 10;
char c = 'a';

明确初始化与赋值概念的不同

初始化:指的是变量与生俱来的内容属性
赋值:指的是后来某个值放到该变量空间的内容属性
两者的注意点在于初始化只能够进行一次,赋值却可以进行无数次。

那我想问,为啥要进行变量定义啊?

首先,我们需要明确的是计算机是弥补人类计算能力低下问题诞生的(这里并没有贬低人类的意思,就是说人类跟计算机相比计算能力确实相对来说比较差)
之后,我们需要明白,我们人类计算时候是需要一步一步计算的,计算机也是需要进行先后计算了,并不是一下子就对所有数据进行处理,计算机也是对一个一个数据进行依次处理的,至于为什么算个数字那么快,因为计算机算的快而已,这并不是说计算机对所有数据进行同时处理。(注:当然计算机也是可以同时对数据进行处理的,不过同时处理数据的能力有限,了解即可)
然后,我们大概就明白了,为何需要变量?就是因为有些数据需要等待一些时间去让计算机处理,在处理之前,需要先存储起来防止数据丢失,这大概跟人类做运算时候要写在纸上差不多,省的忘了原来的数据,如果忘了那就惨了。
那为啥需要把数据放在一个个变量里进行处理啊?我数据直接放那一团不就行了嘛,这有点类似于我们吃饭,我们一般都是用碗吃饭,而不是直接用锅,原因在于效率高,计算机也是一样,在处理数据的时候,先用变量把在“一锅里的”数据分到一个个小碗里,然后就“吃”的快了。而且之前讲过,我们做饭的地方跟我们吃饭的地方离得距离是比较远的,类似于硬盘中的程序跟cpu处理是比较远的,要想提高效率,就是借助变量变成“小碗”送到内存当中,这样就跟cpu离得近了。其实我感觉变量就是起到了一个方便读取数据的作用。

变量定义与声明的本质

根据上面知识我们明白,程序运行,就是把程序加载到内存当中去,程序计算,需要借助变量提高效率。
那么变量的定义的本质是:在内存当中开辟一块空间,用来保存数据。
变量声明的本质就是:告知编译器。

两者的区别在于,声明你可以声明多次,定义只能定义一次哈。
这个区别说明B站的蛋哥有一个比较有意思的比喻,大概是这样的,变量的定义类似于你跟你女朋友表白,只能表白一次吧?哈哈。然后变量的声明的话就是你告诉你周围的人,那个女孩是我女朋友哈,你们不要有非分之想了哈。这里想说声明可以声明无数次。(这里只是做一个比喻说明一下哈,无任何不良诱导)

3.auto关键字(宽容的关键字,可以省略)

这里,我就需要说明一下《深度解剖C语言》这本书的错误之处了,在这本书当中,本书作者是这样描述的:
在这里插入图片描述
在这里所有变量是不正确的哈,比较准确的说法是局部变量

局部变量和全局变量?

在代码块内定义的变量称为局部变量,在代码块之外定义的变量称之为全局变量。
在这里插入图片描述
两者的差别:
存储区域不同:全局变量的存储是存储在全局数据当中的,局部变量是存储在栈空间当中的。
使用优先级不同:如果全局变量跟局部变量定义的标识符名称一样的话,且两者都可以使用的情况下,基本类似于就近原则,谁近就用谁,一般来说局部变量的优先级比较高一些。
在这里插入图片描述

作用域与生命周期?

这其实是一个与变量相联系的两个概念。这里简单说一下:
所谓作用域:指的是某一个变量的作用范围,简单点来说就是变量从什么时候开始有效到什么时候失效的这个代码区间。举个例子来说,局部变量只能在所定义的代码块中使用,那么这个局部变量的作用域就仅限这个代码块,但是一个全局变量,一般就是从开始定义到代码最后,作用域基本就是全局代码(与全局代码定义的地方有关)。
所谓生命周期来说:也是针对于变量来说的,指的是一个变量在内存开辟到变量在内存中释放的这么一个过程范围。举个例子来说,一般全局变量的生命周期是程序开始运行到程序结束。局部变量的声明周期就是从程序运行到该局部变量定义的那个代码块的开始到该代码块运行结束。
需要注意的话,作用域与生命周期不是一个概念哈,虽然说大多时候两者基本是一致的,但是两者的概念一个指的是影响范围(有效区域)一个指的是内存储存的时间,还是不一样的。

首先是那个作用域问题,你的变量如果不在作用域内使用,编译器会报错哈。
之后为了说明生命周期这个问题,我特地编了一段代码给大家体会一下哈,我记得学校C语言考试老喜欢考这个,还每次都能够坑一些“涉世未深”的年轻小伙子:

int main()
{
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		int j = 0;
		printf("这是第%d次打印:\n", i);
		printf("i = %d ", i);
		printf("j = %d\n", j);
		j++;
	}
	return 0;
}

看答案之前自己先想一下打印结果是啥,答案如下:
在这里插入图片描述
之所以j一直是0,原因就在于每次出for循环那个大括号原本的j就销毁了,再次循环进入的时候又是一个新定义的j,所以后面的j++,没用哈。

auto关键字介绍

上面为了说明这个关键字干啥的就做了大量的铺垫,其实在原书中是没有上面铺垫内容的,直接说就会显得很突兀,突然就冒出来了个auto…
如何使用:一般在代码块中定义的变量,这里指的是局部变量,默认都是auto修饰的,不过我们一般写的时候都是省略的哈。
==但是我需要强调的是并不是所有的变量都是auto修饰的,auto仅仅是用来修饰局部变量的。原书中的描述是错误的哈。==可能同学你在没有读本篇文章之前压根不知道有auto这个关键字,我感觉大部分情况都没有写他的必要。。。当长长见识把哈哈,基本用不到所以大部分的一些教材没有涉及到这个关键字,但是我觉得C语言标准给他定义出来,总归是有用的,大概是我目前修行不够还不知道咋用而已吧哈哈。
这里B站蛋哥有个提示哈:就是上面讲解是适合于C语言的,C++对于auto的理解是不同的。

4.register关键字(读取效率最快的关键字)

首先说一下哈,register关键字比较冷门,可能在读本文章的你又没听说过哈。
我们先来铺垫一些概念,就是硬件存储概念:
在这里插入图片描述
看了这幅图,有些聪明的小伙伴可能就会明白,我买的笔记本电脑为啥硬盘有几百个GB甚至几个TB,而内存却小的只有16GB/32GB了,然后CPU更小了,因为越靠近CPU的这些存储硬件,越贵!同时,我们之前说过,程序没有运行之前都放在硬盘了。访问数据的时候,是逐层往上加载缓存,直到CPU(cpu内部有寄存器)进行计算访问。
之后,数据存储靠的cpu越近,访问自然也越快。
==然后register这个关键字,就是尽量让我们定义的一些变量存储在cpu寄存器内。==注意尽量这俩字哈!!!
需要注意的是:
1.rgister关键字是尽量让你定义的变量放在寄存器当中,能存多少,这个问题依靠于环境,编译器和电脑自身分析判断。
2.一个变量如果放在寄存器当中存储,距离cpu是最近的,那么访问速度也将最快。
3.一个变量如果成功放到了寄存器当中,那么它将不存在地址。C语言中所说的地址,是指的是变量在内存中的存储地址,为啥有地址,是为了方便咱们电脑快速找到并访问数据,现在变量都直接在cpu里存储了,都已经访问到了,也就自然不需要地址了。其实这里我还可以用个比喻来说明,就是你朋友要找你玩,自然得要你家地址吧,这就类似于cpu需要放在内存的变量地址一样,但是如果我直接把你放到你朋友面前,根本就不需要地址。
4.定义变量定义到寄存器的建议:这个变量是高频读取的且较少写入的这种变量。

总结

1.本节内容是简单介绍了一下C语言深度解析这本书和我的系列文章,然后重新认识一下最简单的C程序。
2.介绍了两个关键字及其相关概念:suto、register

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

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

相关文章

一起玩儿物联网人工智能小车(ESP32)——19. MicroPython集成开发环境Thonny的安装

摘要&#xff1a;本文主要介绍MicroPython集成开发环境Thonny的安装方法和基本的使用 Thonny是一个开源的、轻量级的MicroPython集成开发环境&#xff0c;它非常的小巧和精简。对于我们日常ESP32的开发来说&#xff0c;已经完全满足要求了。这个开发软件支持windows、Linux和Ma…

聚焦企业未来新发展,同花顺对话麒麟信安杨涛董事长

打好经济增长主动仗 聚焦企业未来新发展 同花顺“对话湖南上市公司高管系列活动” 本期走进麒麟信安 对话麒麟信安杨涛董事长 畅谈国产操作系统领军企业的创新发展之路 并就麒麟信安产品应用布局及 未来发展规划等方面进行深入交流 麒麟信安-成片1改20231218

统一入口,全面提升工作效率,WorkPlus超级APP引领数字化办公新潮流

在数字化办公的时代&#xff0c;企业往往面临着多个应用管理的挑战。员工需要在众多应用之间切换&#xff0c;记忆不同的登录凭证&#xff0c;这不仅分散了注意力&#xff0c;还降低了工作效率。为了应对这一问题&#xff0c;企业需要一站式的解决方案&#xff0c;通过整合繁杂…

盘点2023 | 校企合作结硕果,产教融合谱新篇

回首2023&#xff0c;电巢科技与众多高校建立了紧密的合作关系&#xff0c;以实习就业为导向&#xff0c;帮助学生打开技术和产业视野&#xff0c;提前做好职业发展规划&#xff0c;按照电子行业的企业用人标准&#xff0c;帮助高校进行“人才前置化”培养&#xff0c;并且持续…

4.Python数据序列

Python数据序列 一、作业回顾 1、面试题 有一物,不知其数,三三数之余二,五五数之余三,七七数之余二,问物几何? 白话文:有一个数字,不知道具体是多少,用3去除剩2,用5去除剩3,用7去除剩2个,问这个数是多少?1 ~ 100以内的整数 while循环: # 初始化计数器 i = …

阿里云PolarDB数据库费用价格表

阿里云数据库PolarDB租用价格表&#xff0c;云数据库PolarDB MySQL版2核4GB&#xff08;通用&#xff09;、2个节点、60 GB存储空间55元5天&#xff0c;云数据库 PolarDB 分布式版标准版2核16G&#xff08;通用&#xff09;57.6元3天&#xff0c;阿里云百科aliyunbaike.com分享…

人工智能的基础-深度学习

什么是深度学习? 深度学习是机器学习领域中一个新的研究方向&#xff0c;它被引入机器学习使其更接近于人工智能。 深度学习是机器学习领域中一个新的研究方向&#xff0c;它被引入机器学习使其更接近于最初的目标——人工智能。 深度学习是学习样本数据的内在规律和表示层次&…

uni-app tabbar组件

锋哥原创的uni-app视频教程&#xff1a; 2023版uniapp从入门到上天视频教程(Java后端无废话版)&#xff0c;火爆更新中..._哔哩哔哩_bilibili2023版uniapp从入门到上天视频教程(Java后端无废话版)&#xff0c;火爆更新中...共计23条视频&#xff0c;包括&#xff1a;第1讲 uni…

Android移动端超分辨率调研(未完成 目前自用)

作用 图片加载是目前几乎所有的APP都具备的基础能力&#xff0c;在节省服务商的传输带宽之外&#xff0c;也可以降低用户消费端流量的消耗&#xff0c;提升用户的加载速度。帮助每一个产品用更低的成本达到更好的图片加载效果。 效果 另一方面 用TensorFlow实现的图像极度压…

【Python】pip下载源修改

运行 pip install 命令 会从网站上下载指定的python包&#xff0c;默认是从 https://files.pythonhosted.org/ 网站上下载。 https://files.pythonhosted.org 这是个国外的网站&#xff0c;遇到网络情况不好的时候&#xff0c;可能会下载失败&#xff0c;我们可以通过命令&am…

分布式系统架构设计之分布式系统架构演进和版本管理

在分布式系统的生命周期中&#xff0c;架构演进和版本管理是很重要的两个环节。本部分会介绍分布式系统架构演进的原则、策略以及版本管理的最佳实践&#xff0c;以帮助研发团队更好地应对需求变化、技术发展和系统升级。 架构演进 演进原则 渐进式演进 采用渐进式演进的原…

vue本地缓存搜索记录(最多4条)

核心代码 //保存到搜索历史&#xff0c;最多存四个 item.name和item.code格式为&#xff1a;塞力斯000001var history uni.getStorageSync(history) || [];console.log("history", history)var index history.findIndex((items) > {return item.name items.nam…

Goby 漏洞发布| QNAP NAS authLogin.cgi 命令执行漏洞(CVE-2017-6361)

漏洞名称&#xff1a;QNAP NAS authLogin.cgi 命令执行漏洞&#xff08;CVE-2017-6361&#xff09; English Name&#xff1a;QNAP NAS authLogin.cgi command execution vulnerability (CVE-2017-6361) CVSS core: 9.8 影响资产数&#xff1a; 2637547 漏洞描述&#xff1…

分享72个Python爬虫源码总有一个是你想要的

分享72个Python爬虫源码总有一个是你想要的 学习知识费力气&#xff0c;收集整理更不易。 知识付费甚欢喜&#xff0c;为咱码农谋福利。 链接&#xff1a;https://pan.baidu.com/s/1v2P4l5R6KT2Ul-oe2SF8cw?pwd6666 提取码&#xff1a;6666 项目名称 10 photo websites…

如何在Docker环境下安装火狐浏览器并结合内网穿透工具实现公网访问

文章目录 1. 部署Firefox2. 本地访问Firefox3. Linux安装Cpolar4. 配置Firefox公网地址5. 远程访问Firefox6. 固定Firefox公网地址7. 固定地址访问Firefox Firefox是一款免费开源的网页浏览器&#xff0c;由Mozilla基金会开发和维护。它是第一个成功挑战微软Internet Explorer浏…

【C++入门(一)】:详解C++语言的发展及其重要性

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; C入门到进阶 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f324;️什么是C&#x1f324;️C的发展史&#x1f324;️C的重要性☁️语言的广泛度☁️C的领域⭐…

机器学习之K-means聚类

概念 K-means是一种常用的机器学习算法,用于聚类分析。聚类是一种无监督学习方法,它试图将数据集中的样本划分为具有相似特征的组(簇)。K-means算法的目标是将数据集划分为K个簇,其中每个样本属于与其最近的簇中心。 以下是K-means算法的基本步骤: 选择簇的数量(K值)…

GPT系列概述

OPENAI做的东西 Openai老窝在爱荷华州&#xff0c;微软投资的数据中心 万物皆可GPT下咱们要失业了&#xff1f; 但是世界不仅仅是GPT GPT其实也只是冰山一角&#xff0c;2022年每4天就有一个大型模型问世 GPT历史时刻 GPT-1 带回到2018年的NLP 所有下游任务都需要微调&#x…

【高性能篇】QPS概念、RT概念

什么是QPS&#xff0c;什么是RT&#xff1f; ✔️典型解析✔️扩展知识仓✔️RT ✔️QPS✔️ QPS和TPS✔️并发用户数✔️最佳线程数 ✔️典型解析 QPS&#xff0c;指的是系统每秒能处理的请求数(Query Per Second)&#xff0c;在Web应用中我们更关注的是Web应用每秒能处理的re…

RestClient操作索引库_删除索引库(三)

ES官方提供了各种不同语言的客户端&#xff0c;用来操作ES。这些客户端的本质就是组装DSL语句&#xff0c; 通过http请求发送给ES。 官方文档地址: https://www.elastic.co/quide/en/elasticsearch/client/index.html 目录 一、RestClient操作索引库&#xff08;删除及判断&am…