文章目录 一.感性理解进程地址空间 二.理性认识进程地址空间 1.虚拟和物理地址空间 2.虚拟地址和物理地址联系 a.页表映射 b.写时拷贝 三.为什么要存在进程地址空间 在正式开始之前我们首先来看这样的一个现象...为了更有效的管理和少出错,现代系统提供了虚拟存储器,虚拟存储器为每个进程提供了一个大的,一致的,私有的地址空间,这个地址空间就是进程地址空间。...一个地址空间的大小是由表示最大地址所需要的位数来决定的(现代系统基本为32位或者64位),对于一个32的机器,它有2^32个地址,这些地址都是唯一的,它们能表示的空间范围是4GB。...但是每个进程都认为自己独享4GB的空间,一个进程的虚拟地址就是4GB的空间范围(我没说大小,因为这个空间是虚拟的),即2^32个地址,但对于32位的机器来说总共的物理地址也就是这么多。...而进程往往是多个的,也就是说相同的虚拟地址可能指向不同的物理空间,而不同的虚拟地址也可能指向同一个物理空间。
今天的博文可能会有点枯燥,由于博主的水平有限,希望大家指正博文的缺点 进程地址空间是什么?...其实进程地址空间只是一个比较抽象的存在,它本质上是一种将各个区域划分的内核数据结构,分别与各自的特定进程关联起来,并且各个进程都有自己私有的一份进程地址空间 所以大家还得记住,大家印象当中的那张图不是真实的内存...那不就会出现程序异常的情况吗?那么我们前面也提到了操作系统也会将虚拟地址转化为内存物理地址,那么如何将其转化为物理地址呢? 通过我们的原理就知道了! 进程地址空间的原理 页表!...所以,进程地址空间和页表的出现真正意义上保证了一个进程的独立性! 同时由于页表的映射,也使得内存分布变得有序!...写时拷贝支撑了进程地址空间的存在,保证了进程的正常运行!
真正的物理地址就像真正的奖励,而虚拟地址空间就是那一张张大饼,如果有需要,可以向领导进行申请,其实就相当于 虚拟地址空间向操作系统申请物理地址空间。 那么领导给员工的大饼要不要进行管理呢?...虚拟地址空间本质上就是一种数据结构! task_struct 指向某一个进程地址空间,而进程地址空间以链式结构存储,于是操作系统对进程地址空间的管理,变为对该链表的增删查改!...】 ✈️进程地址空间的属性 那么进程地址空间里的属性字段是怎么一回事呢?...要想更好了解进程地址空间,我们有必要深入学习进程地址空间的属性。 ...进程地址空间本质上也是一种数据结构,并且彼此是链式连接的,于是 操作系统对进程地址空间的管理变为了对链表的增删查改! 我们了解了进程地址空间中一定存在许多的地址划分,用来区分各个地址区域。
在32位和64位下的地址空间大小是不一样的,为了方便这里使用32位来表述。32位从低到高一个有4GB的地址空间范围,实际上这个地址空间当中打印出来的地址,是该空间内对应的地址。...其实PCB和地址空间都是在物理内存里面的,只不过要访问初始化全局数据的时候,不在地址空间上保存,地址空间只会提供线性连续地址,让用户之后通过虚拟地址的地址空间,将虚拟地址转化到为了物理内存中。...每个进程都要有自己独立的地址空间,那么操作系统就得管理很多个进程的地址空间,而地址空间本质上就是内核中的一个数据结构对象。...然后把修改之前的数据拷贝到新空间中,再把新的物理地址和之前的物理地址相比较,把新的物理地址放在子进程的页表中,重新构建映射,页表的右侧就指向新的物理地址空间,这个工作结束,才会就行让子进程执行写入操作,...地址空间 2.1 理解地址空间 地址空间本质是内核的一个struct结构体,结构体里面有各种各样的区域划分,内部有很多的属性都是表示start,end的范围。
我们在使用云服务器的时候,都需要先搭建ftp服务器。而且不同的云服务器的平台,搭建ftp服务的步骤也会有差别。那么什么是ftp?云服务器的ftp地址是什么呢?现在我们就来重点讲解一下。...云服务器的ftp地址是什么 ftp地址其实就是在我们登录ftp后台的时候需要输入的地址,也就是我们常接触的ip地址。...ftp地址的作用与网址的作用是差不多的,也可以在浏览器地址栏内输入ftp地址进行网站访问,只是网址的内容文件是很多人都可以下载的,不用特定用户。...ftp地址的查看方法为:登陆云服务器之后,打开云主机页面,在这里可以看到所有服务器的状态与配置,ftp地址也是可以看到的。...点击右上角的按钮,还可以根据自己的需求查看服务器的详细信息,将鼠标移动到内网ip上,可以看到复制按钮,点击就可以复制该ip地址了。 云服务器的ftp地址是什么?
在 Linux 系统中,每一个进程都在自己独立的地址空间中运行,在 32 位系统中,每个进程的逻辑地址空间均为 4GB,这 4GB 的内存空间按照 3:1 的比例进行分配,其中用户进程享有 3G 的空间...虚拟地址会通过硬件 MMU(内存管理单元)映射到实际的物理地址空间中,建立虚拟地址到物理地址的映射关系后,对虚拟地址的读写操作实际上就是对物理地址的读写操作,MMU 会将物理地址“翻译”为对应的物理地址...所有应用程序运行在自己的虚拟地址空间中,使得进程的虚拟地址空间和物理地址空间隔离开来,这样做带来了很多的优点: ⚫ 进程与进程、进程与内核相互隔离。...一个进程不能读取或修改另一个进程或内核的内存数据,这是因为每一个进程的虚拟地址空间映射到了不同的物理地址空间。提高了系统的安全性与稳定性。 ⚫ 在某些应用场合下,两个或者更多进程能够共享内存。...因为每个进程都有自己的映射表,可以让不同进程的虚拟地址空间映射到相同的物理地址空间中。通常,共享内存可用于实现进程间通信。 ⚫ 便于实现内存保护机制。
,对线性区域进行指定start和end即可完成区域划分 从而说明进程地址空间就是一个线性区域 地址空间上的虚拟地址,一个地址表示一个字节,即虚拟地址地址空间的宽度代表为字节 cpu与内存链接的线称之为系统总线...地址空间存在自己的编制,地址是连续的 把地址空间的整个范围称之为线性空间 该空间中每一个地址表示对应的数字所对应的地址最小是1字节 定义一个整数相当于在内存中开辟4个字节,连续4个字节对应的起始地址对应整形变量的起始地址...,每个地址对应一个字节 地址空间是线性结构的 4.确定地址空间 32位下地址空间默认为0-42亿多 假设空间范围为4GB 设置进程地址空间的结构 struct mm_struct { int code_start...拓展3:重新理解地址空间 程序在被编译的时候,没有被加载到内存,程序内部有地址 源代码被编译的时候,就是按照虚拟地址空间的方式进行对代码和数据就已经编号了对应的编制 虚拟地址不只会影响操作系统,还要让编译器遵守规则...进程地址空间+页表的意义: 1.防止地址随意访问,保护物理内存与其他进程 若没有地址空间的存在,则直接使用cPU调用物理地址,会有野指针的问题存在 2.将进程管理和内存管理进行解耦合 因为有虚拟地址和页表的存在
但是,堆区和栈区的增长的方向是怎样呢?这个好办;方向是比对出来的,我们只需要多申请几次堆空间和栈空间,然后比较地址大小变化。...这里,我还想和大家达成几个共识: 地址空间描述的基本空间大小为字节。 在32位环境下,一共需要2^32个地址。 2^32*1字节=4GB的空间大小。 每个字节都有唯一的地址。 1....如果读取的是内存中的地址,肯定不会出现这样的情况,所以,我们有理由怀疑:读取的根本不是内存中的地址。 但是由此我们就可以知道,程序地址空间并 不是 内存,它的正确叫法为 进程地址空间!...这时,操作系统会为要修改数据的进程开辟一段空间,然后将原来的数据拷贝一份放入新开辟的空间中,然后改变页表的映射关系(虚拟地址相同,但内存地址不同),之后对数据进行修改。...真正的物理地址就像真正的奖励,而虚拟地址空间(mm_struct)就是那一张张大饼,如果有需要,可以向富翁老爹进行申请,其实就相当于 虚拟地址空间向操作系统申请物理地址空间。
文章目录 一、前言 二、什么是进程地址空间 三、进程地址空间如何进行管理 四、为什么会存在进程地址空间 五、进程地址空间区域的严格划分 一、前言 学习Linux系统编程一共要翻越三座大山 – 进程地址空间...二、什么是进程地址空间 我们以前在学习 C/C++ 的动态内存管理的时候,通常把地址空间划分为如下几个区域: 但是我们上面的地址空间是真正的物理空间吗?...实际上操作系统会给每一个进程都创建一个独立的虚拟地址空间,然后通过页表将虚拟地址空间与物理内存一一对应 (映射),我们用户只能得到虚拟地址空间中的虚拟地址,当我们修改虚拟地址中的数据时,操作系统会先通过页表找到对应的物理内存...此时,我们就能解释上面的现象了 – 子进程和父进程都拥有自己的单独的进程地址空间,且子进程的地址空间是从父进程那里拷贝来的,所以最开始二者的 g_val 其实指向同一块物理内存; 现在子进程想要修改自己地址空间中...为什么还要耗费时间和空间创建虚拟地址空间以及页表呢?这时候就需要引入进程地址空间的优势了,进程地址空间主要有如下三方面的优势。 1、进程地址空间保证了数据的安全性。
一、关于进程地址空间的简单理解 进程地址空间其实是分了很多个区域的,区域划分的本质就是区域内的各个地址都是可以使用的。...进程地址空间不是真实的物理内存,叫做虚拟内存。每一个进程都有自己独立的PCB,也有自己独立的地址空间。在32位机器下,进程地址空间的大小为[0,4GB]。...其中,PCB会记录一个进程的起始地址或基地址,这其实就是进程地址空间的首地址。...当子进程要对数据做修改时会发生写实拷贝,给子进程要修改的数据重新开辟一块物理空间,再将重新开辟的这块物理空间的地址填充入子进程的页表中,但此时页表中对应的虚拟地址并没有发生变化,所以可以看到父子进程访问同一个虚拟地址却打印出不同的内容...所以,进程地址空间就是数据结构,具体到进程中,就是特定数据结构的对象! 二、为什么要有进程地址空间和页表 1、将物理内存从无序变成有序,让进程以统一的视角看待内存。
由于计算机上的很多设备都需要MMIO的地址空间,而每台计算机上所连接的各种设备的对MMIO地址空间的需求是不一样的。...为驱动程序分配4K到1GB的MMIO虚拟地址空间 对于这些虚拟地址空间,添加到VMA中进行统一管理 可以批量释放这些地址空间 这套机制是如何实现的?...这套机制本质上是使用了伙伴系统来对MMIO虚拟地址空间进行维护。在mm/mm.h中指定了MMIO的地址空间范围,这个范围是0xffffa10000000000开始的1TB的空间。...MMIO的映射过程 在得到了虚拟地址空间之后,当我们尝试往这块地址空间内映射内存时,我们可以调用mm_map函数,对这块区域进行映射。 该函数会对MMIO的VMA的映射做出特殊处理。...MMIO虚拟地址空间的释放 当设备被卸载时,驱动程序可以调用mmio_release函数对指定的mmio地址空间进行释放。
Linux进程地址空间 零、前言 一、程序内存空间 二、进程地址空间 1、引入及概念 2、进程地址空间 3、相关问题 零、前言 本章主要讲解学习进程地址空间的知识 一、程序内存空间 在学习C/C...1、引入及概念 对于上述的程序地址空间,其实它的真实面貌为进程地址空间,对于进程地址空间本质上来说是一个虚拟地址空间,并非真实的物理空间 示例: #include #include...,同时也相应的分配了对应的mm_struct进程地址空间(PCB中储存了该进程对应的进程地址空间的地址),也就是每个进程都认为自己独占内存资源 对于进程来说,进程控制块以及进程地址空间以及相应的资源...,随进程的创建而创建,随进程的退出而回收 进程地址空间的内容: 进程地址空间是由0x00000000到0xffffffff的线性地址空间,按照刻度被划分为各个区域,例如代码区、堆区、栈区等...PCB找到对应的进程地址空间,再由进程地址空间上的虚拟地址由页表找到物理空间上分配的数据 示图: 对于父子进程变量地址相同数据不同: 父进程创建子进程时,子进程以父进程为模板构建进程,代码数据父子共享
实际的物理内存程序员是不能直接管理的,在最早期的x86体系结构中。由于实模式,对内存不进行保护,致使病毒蠕虫横飞。出现保护模式以后,提供虚拟地址空间对实际物理内存抽象虚拟,形成一一映射的关系。
为了给进程画饼(让进程认为自己独占操作系统资源),操作系统为每个进程都创建了独立的地址空间,地址空间的内容通过页表映射到物理内存中这样每个进程都能独立的运行。...3.现象的具体解释 父进程和子进程都有自己独立的进程地址空间,也有独立的页表结构。子进程由父进程创建,因此子进程的进程地址空间是拷贝父进程的进程地址空间。...三、怎么办 操作系统要为每一个进程分配地址空间,那么操作系统是否要管理这些地址空间呢?当然是要管理的。 那么,操作系统怎么管理进程的地址空间?...虚拟地址空间是连续的,因此将地址空间划分为不同区域的方法与上面例子的做法类似,我们用一个区域的起始地址start和终止地址end来调整和维护这一块区域。...3-4G是内核空间。 总结 以上就是今天要讲的内容,本文介绍了进程地址空间的相关概念。
当我们返回栈空间地址时会报错,为什么呢?那让我们先看一下什么是返回栈空间地址? 下面是错误示范: vs2022版演示 出现问题,不要慌,那我们就先调试一下。...3.进入GetMory函数,字符型的数组p 赋值为“hello”,return p;p是一个数组,return p;p是数组名,实际是返回的数组的首元素地址‘h’的地址。...当GetMory函数结束时,p就会自动销毁,也就是说p所开辟的空间就会还给操作系统,但p那块空间的地址还存在而且传给了str,当str顺着这个地址访问时,地址原来的空间已经被销毁了,不存在了,但我还要去访问那块空间...答案是肯定哒,yes 上面就是栈空间地址问题的讲解,总结一下简单可以理解为,函数调用如果返回值为一个局部地址,就会出错,除非返回变量,或加上static修饰。...另外加一个知识点,如果空间是在堆区上开辟的,堆区只有 free来释放空间,所以不存在返回占栈空间地址问题。
所以我们能得出结论,我们之前看到的地址,绝对不是物理地址,我们平时用到的地址,其实都是虚拟地址/线性地址! 而虚拟地址就是进程地址空间的内容 2....进程地址空间 我们现在来深入的了解一下为什么相同的的地址为什么会有不同的值? 首先引入一个概念:每一个进程运行之后,都会有一个进程地址空间的存在,在系统层面都要有自己的页表映射结构!...在这个故事中: 操作系统:富豪 内存:10亿美金 进程:私生子 虚拟地址空间:继承10亿的大饼 虚拟地址空间并不是真实的地址 3....每一个进程都要有地址空间,系统中,一定要对地址空间做管理!! 而操作系统管理地址空间,一定是“先描述,在组织”!地址空间最终一定是一个内核的数据结构对象, 就是一个内核结构体!...而我们观察进程地址空间,发现里面是一堆的地址划分。
文章目录 一、虚拟地址空间布局架构 二、用户虚拟地址空间划分 一、虚拟地址空间布局架构 ---- 在 64 位的 Linux 操作系统中 , " ARM64 架构 " 并 不支持 64 位的虚拟地址..., 最大只支持 48 位的虚拟地址 , 64 位地址太大 , 并不需要那么大的内存空间 ; " ARM64 架构 " 中 , Linux 系统的 " 内核虚拟地址 “ 与 ” 用户虚拟地址 "...0000 0000 ~ 0x FFFF FFFF FFFF FFFF , 48 位有效地址 ; 二、用户虚拟地址空间划分 ---- Linux 操作系统 进程 的 " 用户虚拟空间 " 起始地址...为 0 ; " 用户虚拟空间 " 的大小为 TASK_SIZE , 该值与 处理器 架构 有关 , 不同的处理器 , 定义的 TASK_SIZE 宏不同 ; 32 位处理器 定义的 TASK_SIZE..." 虚拟地址空间 " 的地址位数 , TASK_SIZE 与 TASK_SIZE_64 宏 相关源码如下 : /* * PAGE_OFFSET - the virtual address of the
这种做法非常浪费空间,因为每个段都会要求字节对齐要求,比如对于x86空间来说,段的装载地址和空间的对齐单元为页,也就是4096字节。...“链接器为目标文件分配地址和空间”这句话中的“地址和空间”其实有两个含义: 在输出的可执行文件中的空间; 装载后的虚拟地址中的虚拟地址空间。...比如在“.text”和".data"来说,它们在文件中和虚拟地址都要分配空间,因为它们在这两者都存在;而在“.bss”这样的段来说,分配空间只局限与虚拟地址空间,因为它在文件中并没有内容。...==事实上,我们在这里谈到的空间分配只关注于虚拟地址空间分配;== 现在的链接器空间分配策略基本上采用上述方式中的第二种,使用这种方法的链接器一般都采用一种叫两步链接的方法。...在第一步的扫描和空间分配阶段,链接器按照前面介绍的空间分配方法进行分配,这时候输入文件中的各个段在链接后虚拟地址就已经确定,比如“.text”段起始地址为0x08048094,“.data”段的起始地址位
lowmem : 0xc0000000 - 0xd0000000 ( 256 MB) modules : 0xbe600000 - 0xc0000000 ( 26 MB) <<< 模块地址空间...define MODULES_END (PAGE_OFFSET) #define MODULES_VADDR (MODULES_END - 16*1048576) 对于arm平台,默认模块地址空间为...module PLT(Procedure Link Table)机制,让模块加载使用vmalloc空间的方法,解决模块空间不够用的问题。...,模块的地址并不是常见的0xbf打头,而是落在vmalloc区域 image.png 模块空间占用裁减 通过objdump -t命令可以查看模块的所有符号 识别所有符号里的.bss和.data部分,确认是否有大块的变量符号...整改大块的变量符号,将其转变为动态申请的内存形式
内核线程被调度执行时确实需要一个地址空间,但这个地址空间并不是为每个内核线程独立创建的。内核线程运行在操作系统的内核空间中,而不是在用户空间。...以下是内核线程执行时地址空间的来源和管理方式: 地址空间来源 共享内核地址空间: 所有内核线程共享内核地址空间,这包括内核代码段、内核数据段、内核堆、内核栈等。...内核地址空间是整个操作系统的一部分,不是为每个线程独立创建的。每个内核线程在执行时,都使用这个共享的内核地址空间。 内核栈: 尽管所有内核线程共享内核地址空间,每个内核线程都有自己的内核栈。...使用内核地址空间: 由于所有内核线程共享内核地址空间,调度器无需切换地址空间映射(不像用户态进程需要切换页表)。内核线程可以直接使用共享的内核代码段、数据段和堆。...整个过程中,内核地址空间(代码段、数据段、堆等)是共享的,唯一需要切换的是内核栈和线程的上下文信息。 总结 内核线程被调度执行时使用的地址空间是整个操作系统的共享内核地址空间。
领取专属 10元无门槛券
手把手带您无忧上云