【C++奇遇记】内存模型

这篇具有很好参考价值的文章主要介绍了【C++奇遇记】内存模型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🎬 博客主页:博主链接
🎥 本文由 M malloc 原创,首发于 CSDN🙉
🎄 学习专栏推荐:LeetCode刷题集 数据库专栏 初阶数据结构
🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
📆 未来很长,值得我们全力奔赴更美好的生活✨

【C++奇遇记】内存模型,c++奇遇记,c++,开发语言
【C++奇遇记】内存模型,c++奇遇记,c++,开发语言

😇本章详情

🐤本篇文章将讲授C++的内存模型相关的知识

😇内存模型的前情介绍

😁程序的三大组成部件:

  1. 头文件:包含结构声明和使用这些结构的函数的原型
  2. 源代码文件:包含与结构有关的函数代码
  3. 源代码文件:包含调用与结构相关的函数的代码

这是一种非常用的组织程序的策略。例如,如果编写另一个程序时,也需要使用这些函数,则只需包含头文件,并将函数文件添加到项目列表或make列表即可。

😇头文件管理

📝在同一个文件中只能将同一个头文件包含一次。记住这个规则很容易,但很可能在不知情的情况下将头文件包含多次。例如使用包含了另外一个头文件的头文件。有一种标准的C/C++技术可以避免多次包含同一个头文件。它是基于预处理器编译指令#ifndef(即if not defined)的。下面的代码片段意味着仅当以前没有使用预处理器编译指令#define定义名称COORDIN_H_时,才处理#ifndef和#endif之间的语句:

#ifndef COORDIN_H_

#endif
通常,使用#define语句来创建符号常量,如下所示:
#define MAXIMUM 4096
但只要将#define用于名称,就足以完成该名称的定义,如下所示:
#define COORDIN_H_

#ifndef COORDIN_H_
#define COORDIN_H_
//place include file contents here
#endif

上述代码解释
编译器首次遇到该文件时,名称COORDIN_H_没有定义(我们根据include文件名来选择名称,并加上一些下划线,一创建一个在其他地方不太可能被定义的名称)。在这种情狂下,编译器将查看#ifndef和#endif之间的内容(这正是我们希望的),并读取定义COORDIN_H_的一行。如果在同一个文件中遇到其他包含coordin.h的代码,编译器将知道COORDIN_H_已经被定义了,从而跳到#endif后面的一行上。注意,这种方法并不能防止编译器将文件包含两次,而只是让它忽略第一次包含之外的所有内容。

📝多个库的链接

前言

C++标准允许每个编译器设计人员以他认为合适的方式实现名称修饰,因此有不同编译器创建的二进制模块(对象代码文件)很可能无法正确地链接。也就是说,两个编译器将为同一个函数生成不同的修饰名称。名称不同将使链接器无法将一个编译器生成的函数调用与另一个编译器生成的函数定义匹配。

✉作用域和链接

📋作用域

💐作用域(scope)描述了名称在文件的多大范围内可见。例如,函数中定义的变量可在该函数中使用,但不能在其他函数中使用;而在文件中的函数定义之前定义的变量则可在所有函数中使用。


C++变量的作用域有多种。作用域为局部的变量只在定义它的代码块中可用。代码块是由花括号括起的一系列语句。例如函数体就是代码块,但可以在函数体中嵌入其他代码块。作用域为全局的变量在定义位置到文件结尾之间都可用。自动变量的作用域为局部,静态变量的作用域是全局还是局部取决于它是如何被定义的。

📋链接性(linkage)

描述了名称如何在不同单元间共享。链接性为外部的名称可在文件见共享,链接性为内部的名称只能由一个文件中的函数共享。自动变量的名称没有链接性,因为他们不能共享。

😇自动存储持续性

📖在默认情狂下,在函数中声明的函数参数和变量的存储持续性为自动,作用域为局部,没有链接性。也就是说,如果在main()中声明了一个名为texas的变量,并在函数oil()中也声明了一个名为texas变量,则创建了两个独立的变量—只有在定义它们的函数中才能使用它们。对oil()中的Texas执行的任何操作都不会影响main()中的texas,反之则亦然。另外,当程序开始执行这些变量所属的代码块时,将为其分配内存;当函数结束时,这些变量将消失。

静态持续变量

C++也为静态存储持续性变量提供了3种链接性:外部链接性(可在其他文件中访问)、内部链接性(只能在当前文件中访问)和无链接性(只能在当前函数或代码块中访问)。这三种链接性都在整个程序执行期间存在,与自动变量相比,它们的寿命更长。由于静态变量的数目在程序运行期间时不变的,因此程序不需要使用特殊的装置(如栈来管理它们)


代码介绍

int global = 1000;// static duration, external linkage
static int one_file = 50;// static duration, internal linkage

int main()
{

}
void funct1()
{
	static int count = 0;//static duration, no linkage
	int llama = 0;
}

正如前面指出,所有的静态持续变量(global,one_file 和 count)在整个程序执行期间都存在。在函数funct1中声明的变量count的作用域为局部,没有链接性,这意味着只能在funct1函数中使用它,就像自动变量llama一样。然后,与llama不同的时,即使在funct1函数没有被执行的时候,count也留在内存中。由于one_file的链接性为内部,因此只能在上述代码的文件中使用它;由于global的链接性为外部,因此可以在程序的其他文件中使用它

📃如何巩固学习

提示:在学习的过程中,我们需要先自行进行思考,并且多去阅读一些大佬的书籍,俗话说的好,书籍是人类进步的阶梯!

📃本文小结

  1. C++鼓励程序员在开发程序时使用多个文件。一种有效的组织策略是,使用头文件来定义,为操纵用户类型的函数提供函数原型;并将函数定义放在一个独立的源代码文件中。头文件和源代码文件一起定义和实现了用户定义的类型及其使用方式。最后,将main()和其他使用这些函数的函数放在第三个文件中。

好啦今日的分享到这里就结束啦,我是爱你们的M malloc希望可以帮助到你们噢,最后别忘记三连啦!!

【C++奇遇记】内存模型,c++奇遇记,c++,开发语言

【C++奇遇记】内存模型,c++奇遇记,c++,开发语言文章来源地址https://www.toymoban.com/news/detail-670836.html

到了这里,关于【C++奇遇记】内存模型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【C++奇遇记】构造函数 | 初始化列表

    🎬 博客主页:博主链接 🎥 本文由 M malloc 原创,首发于 CSDN🙉 🎄 学习专栏推荐:LeetCode刷题集 数据库专栏 初阶数据结构 🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📆 未来很长,值得我们全力奔赴更美好的生活✨ 🐤本篇文章将讲授C++的初始化列表相关的知识

    2024年02月12日
    浏览(45)
  • C++内存分区模型

    在执行C++程序的过程中,内存大致分为四个区域: 栈区(Stack) :用于实现函数调用。由编译器自动分配释放,存放函数的参数值和局部变量等 堆区(Heap) :用于存放动态分配的变量。由程序员动态分配和释放,使用new和delete操作符 全局/静态存储区(Data Segment BSS Segment) :存放全

    2024年02月16日
    浏览(30)
  • C++基础——内存分区模型

    C++程序在执行是,将内存大致分为4个区域: 代码区:用于存放二进制代码,由操作系统进行管理 全局区:存放全局变量和静态变量及常量 栈区:由编译器自动分配释放,存放函数的参数、局部变量等 堆区:程序员分配,如果程序员不释放,程序结束后由操作系统回收 内存

    2024年02月07日
    浏览(30)
  • Day 9 C++ 内存分区模型

    目录 内存四区 代码区 全局区 栈区 堆区 内存四区意义: 程序运行前后内存变化 程序运行前 代码区 全局区  程序运行后 栈区 堆区 new操作符 基本语法 创建 释放(delete) 代码区 代码区 (Code Segment):存放程序的机器指令,包括函数体的二进制代码。这部分内存由操作系统

    2024年02月15日
    浏览(62)
  • C语言内存模型的深度剖析

    在计算机体系结构中,内存被抽象为一个线性的地址空间,C语言内存模型即建立在此基础之上。每个存储单元都有一个唯一的地址,这个地址空间从0开始递增,范围受限于处理器架构和操作系统提供的物理或虚拟内存大小。 在C语言中,所有对象(包括变量、数组、结构体等

    2024年02月22日
    浏览(29)
  • C++面向对象丨1. 内存分区模型

    Author:AXYZdong 硕士在读 工科男 有一点思考,有一点想法,有一点理性! 定个小小目标,努力成为习惯!在最美的年华遇见更好的自己! CSDN@AXYZdong,CSDN首发,AXYZdong原创 唯一博客更新的地址为: 👉 AXYZdong的博客 👈 B站主页为: AXYZdong的个人主页 系列文章目录 C++基础入门

    2023年04月18日
    浏览(28)
  • C++奇迹之旅:探索类对象模型内存的存储猜想

    上回我们学习了类的定义,初步了解了什么是类?类的定义,以及类的三个访问限定符: public , private , protected ,本小节将讲解类的实例化,类对象模型的猜想存储,及三种简单类的计算。 在 C++ 中,类的实例化是指创建一个类的对象。当我们定义了一个类之后,就可以根据

    2024年04月12日
    浏览(29)
  • 第八十五天学习记录:C++核心:内存分区模型

    C++程序在执行时,将内存大方向划分为4个区域 1、代码区:存放函数体的二进制代码,由操作系统进行管理 2、全局区:存放全局变量和静态变量以及常量 3、栈区:由编译器自动分配释放,存放函数的参数值,局部变量等 4、堆区:由程序员分配和释放,若程序员不释放,程

    2024年02月12日
    浏览(35)
  • 省显存(内存?)的大语言模型(LLMs)训练/微调/推理方法

    即使 RTX 3090 有着 24GB 的 RAM,使用一块 RTX 3090 依然无法 fp32 精度训练最小号的 LLaMA-6B。 估算模型所需的RAM 首先,需要了解如何根据参数量估计模型大致所需的 RAM,这在实践中有很重要的参考意义。需要通过估算设置 batch_size,设置模型精度,选择微调方法和参数分布方法等

    2024年02月09日
    浏览(29)
  • C++与C语言动态内存管理的不同 new与malloc

      目录 1.C语言动态内存管理方式 2.C++中动态内存管理 2.1 new和delete操作内置类型 2.2 new和delete操作自定类型 2.3 为什么delete要带[ ]  3.new申请空间失败 4.operator new 与 operator delete 函数 5.new与delete的是实现原理 5.1 内置类型 5.2 自定义类型 6.定位new表达式(了解即可) 7.malloc/free和

    2024年02月08日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包