精华内容
下载资源
问答
  • 虚拟地址

    千次阅读 2020-02-06 18:08:59
    虚拟地址 虚拟地址是程序运行在保护模式下,这样程序访问存储器所使用的逻辑地址称为虚拟地址。 那为什么需要虚拟地址呢 我们要说到寻址方式 寻址:根据指令内容确定操作数地址的过程,称为寻址 在16位的cup或者8086...

    虚拟地址

    虚拟地址是程序运行在保护模式下,这样程序访问存储器所使用的逻辑地址称为虚拟地址。

    那为什么需要虚拟地址呢

    我们要说到寻址方式
    寻址:根据指令内容确定操作数地址的过程,称为寻址

    在16位的cup或者8086cpu的时候,他寻址方式的模式为:实模式
    而在32位或者64位,寻址方式的模式为:保护模式

    实模式

    我们先来看一下实模式下程序的运行
    例:

    在这里插入图片描述
    如图,在实模式中,A程序和B程序从磁盘直接加载进内存中运行,我们所看到或者得到的就是物理地址,我们都知道内存是连续的,现在假设A程序是恶意程序,他现在可以通过自己运行时所获取的物理地址加上偏移就可以进入B程序中,可以篡改B程序的指令或者数据,导致B程序崩溃或者出错

    保护模式

    我们继续来看一下保护模式下程序的运行
    例:

    在这里插入图片描述
    在保护模式中,在程序从磁盘加载进内存的中间加了一个中间层,即就是虚拟地址,在程序编译,链接的时候先映射进虚拟地址,在运行的时候会在映射进物理地址

    这样的模式好处在于,在虚拟地址中,如图B程序的虚拟地址,不管通过如何偏移,他都在虚拟地址中,最后映射进物理地址也在B程序内,不会影响到其他的程序,起到了进程隔离,保护了其他的进程

    所以如今的寻址方式的模式大都是以保护模式为主,也就是虚拟地址空间,因为其更能保证进程的安全和跟合理的安排程序运行

    虚拟地址空间

    在32位操作系统中虚拟地址空间大小为4G
    而在虚拟地址里用户空间和内核空间的比例划分为
    Windows是2:2划分的
    Linux是3:1划分的

    linux虚拟地址空间图如下

    在这里插入图片描述

    展开全文
  • 虚拟地址空间

    千次阅读 多人点赞 2019-03-13 03:32:18
    对于每一个进程都会对应一个虚拟地址空间,对于32位的操作系统(其指令的位数最大为32位,因此地址码最多32位),虚拟地址空间的大小为B即0~4GB的虚拟地址空间,其中内核空间为1GB,如下所示: 每一个进程的进程...

            对于每一个进程都会对应一个虚拟地址空间,对于32位的操作系统(其指令的位数最大为32位,因此地址码最多32位),虚拟地址空间的大小为2^{32}B即0~4GB的虚拟地址空间,其中内核空间为1GB,如下所示:

             每一个进程的进程控制块PCB都位于内核区,在每一个进程的PCB中有一个文件描述符表(是一个数组),用于标记该进程所打开的所有文件。从文件描述符表可以看出每一个进程最多能打开1024个文件,其中有三个文件默认是一直处于打开状态的(即进程创建完成时就处于打开状态),分别是:标准输入 STDIN_FILENO,其文件描述符为0;标准输出 STDOUT_FILENO,其文件描述符为1;错误输出 STDERR_FILENO,其文件描述符为2,其中文件描述符0和1可以省略不写。供我们用户打开的文件,只能够占据从3开始的位置(即其文件描述符为3以后的数字,3~1023)。每打开一个文件就会占用一个文件描述符,且使用的是空闲的最小的一个文件描述符。

            Linux下可执行文件的格式为ELF:[root@localhost Calc]# file zsx
                                                                         zsx: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=0x14ef2d34126e7c54141b73c31968bd825ca522ba, not stripped           //可以看出zsx为64位(即机器指令位数为64位,OS位数)的可执行文件,其格式为ELF。

            对于每一个程序在执行时(如上图中的a.out),此时会产生一个相应的进程,系统都会自动为其分配一个0~4G的虚拟地址空间,其中1G的内核空间用于:进程管理、内存管理、设备管理和虚拟文件系统等。下面详细介绍0~3G的用户空间。

             强调一点:以下说明的各段都是与编程相关的,不包括虚拟地址空间的全部。

            0~3G的用户空间。从小到大(从下往上)依次为:保留区(受保护的地址)、代码段、数据段(.data段)、.bss段、堆空间、内存映射段、栈空间、命令行参数和环境变量。下面依次对每一个段做简单的介绍:

    1.保留区(受保护的地址)

            保留区即为受保护的地址,大小为0~4K,位于虚拟地址空间的最低部分,未赋予物理地址(不会与内存地址相对应,因此其不会放任何内容)。任何对它的引用都是非法的,用于捕捉使用空指针和小整型值指针引用内存的异常情况。大多数操作系统中,极小的地址通常都是不允许访问的,如NULL。C语言将无效指针赋值为0也是出于这种考虑,因为0地址上正常情况下不会存放有效的可访问数据。将指针赋值为0,意味着该指针将永远不会被使用,从而不会出现野指针情况。#define NULL 0 与 #define NULL (void*)0   在C语言中是等效的,而在C++中,只能用#define NULL 0,后面 #define NULL (void*)0的使用会出错。

    2.代码段

            代码段也称正文段或文本段,通常用于存放程序执行代码(即CPU执行的机器指令)。一般C语言执行语句都编译成机器代码保存在代码段。通常代码段是可共享的,因此频繁执行的程序只需要在内存中拥有一份拷贝即可。代码段通常属于只读,以防止其他程序意外地修改其指令(对该段的写操作将导致段错误)。某些架构也允许代码段为可写,即允许修改程序。  

    3.数据段(.data段)

            数据段通常用于存放程序中已初始化的全局变量和静态局部变量。数据段属于静态内存分配(静态存储区),可读可写。由于全局变量未初始化时,其默认值为0,因此值为0的全局变量位于.bbs段(不位于数据段)。对于未初始化的局部变量,其值是不可预测的。注意:在代码段和数据段之间还包括其它段:只读数据段和符号段等。

    4..bbs段

            该段用于存放未初始化的全局变量和静态局部变量,包括值为0的全局变量。 数据段和.bbs段又称为全局数据区,前者初始化,后者未初始化。

            ELF段包括:代码段、其它段(只读数据段和符号段等)、.data段(数据段)和.bbs段,都属于可执行程序部分。

    5.堆空间

            new( )和malloc( )函数分配的空间就属于对空间,用于内存空间的分配,其从下往上。  堆用于存放进程运行时动态分配的内存段,可动态扩张或缩减。堆中内容是匿名的,不能按名字直接访问,只能通过指针间接访问。当进程调用malloc(C) 和new (C++)等函数分配内存时,新分配的内存动态添加到堆上(扩张);当调用free(C)/delete(C++)等函数释放内存时,被释放的内存从堆中剔除(缩减) 。

    6.内存映射段(共享库)

            此处,内核将硬盘文件的内容直接映射到内存, 任何应用程序都可通过Linux的mmap()系统调用请求这种映射。内存映射是一种方便高效的文件I/O方式, 因而被用于装载动态共享库。如C标准库函数(fread、fwrite、fopen等)和Linux系统I/O函数,它们都是动态库函数,其中C标准库函数都被封装在了/lib/libc.so库文件中,都是二进制文件。这些动态库函数都是与位置无关的代码,即每次被加载进入内存映射区时的位置都是不一样的,因此使用的是其本身的逻辑地址,经过变换成线性地址(虚拟地址),然后再映射到内存。而静态库不一样,由于静态库被链接到可执行文件中,因此其位于代码段,每次在地址空间中的位置都是固定的。

    7.栈空间

            用于存放局部变量(非静态局部变量,C语言称为自动变量),分配存储空间时从上往下。栈和堆都是后进先出的数据结构。

    8.命令行参数

            该段用于存放命令行参数的内容:argc和argv。

    9.环境变量

            用于存放当前的环境变量,在Linux中用env命令可以查看其值。

    10.虚拟地址空间的作用(好处)

            1.方面编译器和操作系统安排程序的地址;2.方便实现各个进程空间之间的隔离,互不干扰,因为每个进程都对应自己的虚拟地址空间;3.实现虚拟存储,从逻辑上扩大了内存。

    补充内容:

    代码段(.text段)与只读数据段和符号段(.rodata段),都属于只能读的部分,在链接的时候这两部分会链接成为一个整体;而.data段和.bbs段属于可读可写RW的部分。这四个部分都是以页(每页4KB)的形式存放在内存中。进程控制块PCB(又叫进程描述符)放于内核空间

    多个进程在并发执行时,这些进程的用户空间都是彼此独立的,因此各个进程的用户空间在映射为内存空间使都是独立的,互不干扰,这是MMU地址变换必须要能够保证的。例如,各个进程的.text段、只读数据段和符号段、.data段和.bbs段等在用户空间中使用到的其它数据信息,都会与页为基本单位放在内存中,各个进程的映射是独立的。而对于内核空间,由于只有一个操作系统,内核空间主要是 机器指令、操作系统内核的各个模块等,它们是公用的,因此每个进程的映射方式一样。强调一点:每个进程用到或即将用到的数据才会调入内存,其余都在磁盘上。但是各个进程内核空间的进程控制块(进程描述符)映射的地点是不一样的,也是相互独立的。共用的模块才是一样的。 这些都是MMU的实现机制所决定的。如果感兴趣,可以看看MMU的实现机制。

    展开全文
  • 物理地址、虚拟地址

    千次阅读 2020-10-11 21:16:36
    在程序指令中的虚拟地址经过段映射和页面映射后,就生成了物理地址,这个物理地址被放到CPU的地址线上。 (2)总线地址 总线的地址线或在地址周期上产生的信号。外设使用的是地址总线,cpu使用的是物理地址。 ...

    (1)物理地址

    CPU地址总线传来的地址,由硬件电路控制其具体含义。物理地址中很大一部分是留给内存条中内存的,但也常被映射到其他存储器上(如显存、bios等)。在程序指令中的虚拟地址经过段映射和页面映射后,就生成了物理地址,这个物理地址被放到CPU的地址线上。

    (2)总线地址

    总线的地址线或在地址周期上产生的信号。外设使用的是地址总线,cpu使用的是物理地址。

    物理地址和总线地址之间的关系有系统设计决定的。在X86平台上,物理地址就是总线地址,这是因为它们共享相同的地址空间。在其他平台上,可能需要转换/映射。

    (3)虚拟地址

    现代操作系统普遍采用虚拟内存管理(virtual memory management)机制,这需要MMU的支持。MMU通常是CPU的一部分,如果处理器没有MMU,或者有MMU但没有启用,CPU执行单元发出的内存地址将直接传到芯片引脚上,被内存芯片(物理内存)接收,这成为物理地址,如果处理器启用了MMU,CPU执行单元发出的内存地址将被MMU截获,从CPU到MMU的地址称为虚拟地址,而MMU将这个地址翻译成另一个地址发到CPU芯片的外部地址引脚上,也就是讲虚拟地址映射成物理地址。

          linux中,进程的4GB内存分为用户空间和内核空间。用户空间分布为1~3GB剩下的1GB为内核空间。程序员只能使用虚拟地址。系统中每个进程有各自的私有用户控件(0~3GB),这个空间对系统中的其他进程是不可见的。

    编址方式

    展开全文
  • 物理地址:这里说的物理地址是内存中的内存单元实际地址,不是外部总线连接的...虚拟地址虚拟地址是CPU保护模式下的一个概念,保护模式是80286系列和之后的x86兼容CPU操作模式,在CPU引导完操作系统内核后,操作系...

    物理地址:

    这里说的物理地址是内存中的内存单元实际地址,不是外部总线连接的其他电子元件的地址!

    物理地址属于比较好理解的,物理地址就是内存中每个内存单元的编号,这个编号是顺序排好的,物理地址的大小决定了内存中有多少个内存单元,物理地址的大小由地址总线的位宽决定!

    虚拟地址:

    虚拟地址是CPU保护模式下的一个概念,保护模式是80286系列和之后的x86兼容CPU操作模式,在CPU引导完操作系统内核后,操作系统内核会进入一种CPU保护模式,也叫虚拟内存管理,在这之后的程序在运行时都处于虚拟内存当中,虚拟内存里的所有地址都是不直接的,所以你有时候可以看到一个虚拟地址对应不同的物理地址,比如A进程里的call函数入口虚拟地址是0x001,而B也是,但是它俩对应的物理地址却是不同的,操作系统采用这种内存管理方法

    1.      是防止程序对物理地址写数据造成一些不可必要的问题,比如知道了A进程的物理地址,那么向这个地址写入数据就会造成A进程出现问题,在虚拟内存中运行程序永远不知道自己处于内存中那一段的物理地址上!

    现在操作系统运行在保护模式下即便知道其他进程的物理地址也不允许向其写入!但是可以通过操作系统留下的后门函数获取该进程上的虚拟地址空间所有控制权限并写入指定数据,详细会在反汇编编程中教给大家!

    2.      虚拟内存管理采用一种拆东墙补西墙的形式,所以虚拟内存的内存会比物理内存要大许多。

    在进入虚拟模式之前CPU以及Bootloader(BootLoader是在操作系统内核运行之前运行。可以初始化硬件设备、建立内存空间映射图,从而将系统的软硬件环境带到一个合适状态,以便为最终调用操作系统内核准备好正确的环境),操作系统内核均运行在实模式下,直接对物理地址进行操作!

    虚拟内存中也有分页管理,这种管理方法是为了确保内存中不会出现内存碎片,当操作系统内核初始化完毕内存中的分页表后CPU的分页标志位会被设置,这个分页标志位是给MMU看的!

    分页管理:

    内存分页其实就是我们所说的4G空间,内存的所有内存被操作系统内核以4G为每页划分开,当我们程序运行时会被加载到内存中的4G空间里,其实说是有4G其实并没有真正在的4G空间,4G空间中有一小部分被映射到了物理内存中,或者被映射到了硬盘的文件上(fopen),或者没有被映射,还有一部分在内存当中就会被划分栈,堆,其中有大片大片的内存是没有被映射的,同样物理内存也是被分页了用来与虚拟内存产生映射关系!

    其实真正情况下只有3G用户空间,假如你的内存是4G的那么其中有1G是给操作系统内核使用的,所谓的4G空间只是操作系统基于虚拟内存这种拆东墙补西墙的形式给你一种感觉每个进程都有4G的可用空间一样!

    这里来说一下拆东墙补西墙,当我们程序被加载进4G空间时其实根本用不了所谓的4G空间,其中有大片内存被闲置,那么这个时候呢,其他程序被加载进来时发现内存不够了,就把其他程序里的4G空间里闲置部分拿出来给这个进程用,换之这个进程内存不够时就会把其他进程里闲置的空间拿过来给该进程使用。银行也是如此!

    当我们要对物理地址做操作时比如if语句要根据CPU的状态标志寄存器来做不同的跳转,那么这个时候就要对CPU额状态寄存器做操作了就必须知道它的物理地址,内存中有一个电子元件叫MMU负责从操作系统已经初始化好的内存映射表里查询与虚拟地址对应的物理地址并转换,比如mov 0x4h8这个是虚拟地址,当我们要对这个虚拟地址里写数据时那么MMU会先判断CPU的分页状态寄存器里的标志状态是否被设定,如果被设定那么MMU就会捕获这个虚拟地址物理并在操作系统内核初始化好的内存映射表里查询与之对应的物理地址,并将其转换成真正的实际物理地址,然后在对这个实际的物理地址给CPU,在由CPU去执行对应的命令,相反CPU往内存里读数据时比如A进程要读取内存中某个虚拟地址的数据,A进程里的指令给的是虚拟地址,MMU首先会检查CPU的分页状态寄存器标志位是否被设置,如果被设置MMU会捕获这个虚拟地址并将其转换成相应的物理地址然后提交给CPU,在由CPU到内存中去取数据!

    当我们内存中的容量不够时CPU会从磁盘中分割内存出来给程序用,当然磁盘分割出来的程序速度要慢许多,具体请查看“深度理解指令集”这篇文章!

     

    内存碎片,内存碎片分为两种,一种是内部碎片和外部碎片!

    内部碎片:

    内部碎片是指在内存中已经被分配出去的内存,但是进程不使用这一块内存,进程却一直占用着导致操作系统无法回收给其他进程使用,为了有效的防止这种空间上的浪费现象所以使用了内存分页管理机制!

    操作系统在内存中会维护一个内存信息分页表用于标示某段到某段为个页面!

     

     

    比如在内存中分配这样的一个地址,当ID为1的内存不用了,但是该进程一直占用着这段ID0-2的内存,所以如果此时分配一个长度为2字节的内存空间,ID1的内存刚好足够分配但是这段地址一直被该进程所占用着,所以无法分配!

    后来Intel工程师为了防止这种情况的出现用页为单位的内存管理方式,有效的防止了这种内存碎片的情况发生!

     

    这样的话页ID为1的地方为单独的一个页,当进程不使用时操作系统可以将该页内存分配给其他进程所使用!

    但是这种分页内存往往也会出现一些内存碎片,比如分页分到最后剩下一部分不足以分配给其他进程所使用的内存页面也称为内部碎片,只不过这种浪费比原本的浪费要节约许多!

    外部碎片:

    外部碎片是指还没有被分配的内存空间,但是这些空间因为拆东墙补西墙的原因导致内存地址不连续,也无法分配给其他进程使用,或者地址连续但是却因为容量太小无法分配给其他进程使用!

     

    逻辑地址:

    逻辑地址由两部份组成,段标识符和段内偏移量。段标识符是由一个16位长的字段组成,称为段选择符。其中前13位是一个索引号。后面3位包含一些硬件细节,如图(转载百度百科):

     

     

     

    逻辑地址即程序中的段地址,比如说0x1到0x4为一个页面,那么0x1-0x4之间的段地址称为逻辑地址,逻辑地址可以通过内存中的段数组里寻找段选择符+段偏移地址轻易得到物理地址。

    一般操作系统需要维护两个段描述表:GDT(全局描述符表GDTGlobalDescriptor Table在整个系统中,全局描述符表GDT只有一张(一个处理器对应一个GDT),GDT可以被放在内存的任何位置,但CPU必须知道GDT的入口,也就是基地址放在哪里,Intel的设计者门提供了一个寄存器GDTR用来存放GDT的入口地址,程序员将GDT设定在内存中某个位置之后,可以通过LGDT指令将GDT的入口地址装入此寄存器,从此以后,CPU就根据此寄存器中的内容作为GDT的入口来访问GDT了。GDTR中存放的是GDT在内存中的基地址和其表长界限。),LDT(局部描述符表可以有若干张,每个进程任务都有一张,LDT对应GDT里的某段子描述符,可以把LDT理解成二级描述符,GDT为一级描述符,LDT的入口地址保存在LDTR的寄存器里)。

    如图所示:

     

     

     

    GDT在内存中的地址和大小存放在CPUgdtr控制寄存器中,而LDT则在ldtr寄存器中。

    什么时候使用全局和局部的呢?这是由段描述符中的T1字段表示的,=0,表示用GDT=1表示用LDT

    局部的表示进程自己的,仅进程自己可以使用,全局的则表示操作系统等所有进程都可以使用!

    如果不使用段偏移表示地址的话则称为虚拟地址!

    线性地址:

    线性地址是逻辑地址到物理地址之间的一个中间层变换,程序代码会产生逻辑地址,或者说是段中的偏移地址,加上相应段的基地址就生成了一个线性地址,逻辑地址是如何知道自己的段基的址?是通过局部LDT段描述符获取的。

    如果启用了分页机制,那么MMU内存管理单元会在内存映射表里寻找与线性地址对应的物理地址。若没有启用分页机制,那么线性地址直接就是物理地址。Intel 80386的线性地址空间容量为4G(2的32次方即32根地址总线寻址)。

     

    总结:

    1.虚拟地址是CPU保护模式下的一个概念,保护模式是80286系列和之后的x86兼容CPU操作模式,在进入虚拟模式之前CPU以及Bootloader,操作系统内核均运行在实模式下,直接对物理地址进行操作!

    2.虚拟内存中也有分页管理,这种管理方法是为了确保内存中不会出现内存碎片,当操作系统内核初始化完毕内存中的分页表后CPU的分页标志位会被设置,这个分页标志位是给MMU看的!

    3.虚拟内存采用一种拆东墙补西墙的形式让每个进程都拥有3G用户空间!

    4.当内存中的容量不够时会从磁盘中切割内存出来供进程使用!

    5.内部碎片:

    内部碎片是指在内存中已经被分配出去的内存,但是进程不使用这一块内存,进程却一直占用着导致操作系统无法回收给其他进程使用!

    6.外部碎片:

    外部碎片是指还没有被分配的内存空间,但是这些空间因为拆东墙补西墙的原因导致内存地址不连续,也无法分配给其他进程使用,或者地址连续但是却因为容量太小无法分配给其他进程使用!

     

    7.内存中有一个叫MMU(内存管理单元)的电子元件负责从操作系统已经初始化好的内存映射表里查询与虚拟地址对应的物理地址并转换,

    8.逻辑地址由两部份组成,段标识符和段内偏移量

    逻辑地址即程序中的段地址,比如说0x1到0x4为一个页面,那么0x1-0x4之间的段地址称为逻辑地址,逻辑地址可以通过内存中的段数组里寻找段选择符+段偏移地址轻易得到物理地址。

    线性地址是逻辑地址到物理地址之间的一个中间层变换,程序代码会产生逻辑地址,或者说是段中的偏移地址,加上相应段的基地址就生成了一个线性地址。

     

    展开全文
  • 相对虚拟地址(RVA,Relative Virtual Address),RVA只是内存中的一个简单相对于PE文件装入地址的偏移位置,它是一个“相对地址”,或称“偏移量”。例如,假设一个PE文件从地址400000h处装入,并且它的代码节开始...
  • 1.虚拟内存是内存管理的一种方式, 它在磁盘上划分出一块空间由操作系统管理,当物理内存耗尽是充当物理内存来使用。...2.虚拟地址空间:在多任务操作系统中,每个进程都运行在属于自己的内存沙盘中,这...
  • 虚拟内存/虚拟地址空间

    千次阅读 2019-04-29 11:01:02
    虚拟内存: 也被称作“页面文件”,是一种逻辑上扩充物理内存的技术。...虚拟地址空间:32位CPU的地址总线的是32位的,也就是说可以寻找到2^32(4G)的地址空间。我们的程序被CPU执行,就是在0x000...
  • Linux 虚拟地址到物理地址转换

    千次阅读 2019-03-08 13:58:14
    CPU通过地址来访问内存中的单元,地址有虚拟地址和物理地址之分,如果CPU没有MMU(Memory Management Unit,内存管理单元),或者有MMU但没有启用,CPU核在取指令或访问内存时发出的地址将直接传到CPU芯片的外部地址...
  • 1.物理地址 用于内存芯片级的单元寻址,与处理器和CPU连接的地址总线相对应。 在实地址模式(因为实模式没有分段或分页机制,Cpu不进行自动地址转换)下,程序员...2.虚拟地址 操作系统都提供了虚拟内存(virtual mem
  • 虚拟地址、逻辑地址、线性地址、物理地址的区别1) 虚拟地址:是由程序产生的由段选择符和段内偏移地址组成的地址。这2部分组成的地址并不能直接访问物理内存,而是要通过分段地址的变化处理后才会对应到相应的物理...
  • 虚拟地址到物理地址的映射

    千次阅读 2018-03-07 19:17:54
    虚拟地址和物理地址========================================= CPU通过地址来访问内存中的单元,地址有虚拟地址和物理地址之分,如果CPU没有MMU(Memory Management Unit, 内存管理单元),或者有MMU但没有启用,CPU...
  • 有关计算机操作系统中虚拟地址转换为物理地址的计算 在一个分页虚拟存储系统中,用户编程空间为32个页,页长为1 KB,内存空间为16 KB。如果应用程序有10页长,若已知虚页0、1、2、3,已分得页框4、7、8、10,试把...
  • 虚拟地址与虚拟内存的理解

    千次阅读 2019-04-16 10:38:00
    在最开始看书的时候,我知道程序在运行时,不是全部加入内存当中的,当然,这个现在依旧正确,在有了虚拟地址空间这个概念以后,我一直认为是在硬盘中划分出一块虚拟内存出来,然后给每个程序4G的硬盘空间,作为这个...
  • 逻辑地址、虚拟地址、线性地址、物理地址的区别:虚拟地址:在保护模式下,虚拟地址由段选择子+段内偏移量组成。利用段选择子可以获取到段描述符,再从段描述符中取得段的基地址。也就是说虚拟地址就是xxxx:yyyy ...
  • 虚拟地址做为程序员应该听说的最多,不管是在linux还是windows下编程,程序所操作地址都是虚拟地址虚拟地址是硬件MMU与软件内存管理结合的产物,方便更高效率的使用RAM。内存管理是篇大文章,这里就不聊细节了,...
  • linux虚拟地址转物理地址

    千次阅读 2018-06-21 07:06:00
    80386虚拟地址和物理地址转换CPU的发展之前在看malloc内存分配函数的原理时,有涉及到分配虚拟内存,然后再映射到物理内存,当初也是看得一头雾水,因为对虚拟内存和物...
  • 虚拟地址和虚拟内存区别

    千次阅读 2014-06-20 20:48:37
    程序访问存储器所使用的逻辑地址称为虚拟地址虚拟地址 (virtual address): 4G虚拟地址空间中的地址,程序中使用的都是虚拟地址。每一个进程都分配有一个4G的虚拟地址。通过虚拟地址访问内存的形式称为保护模式,...
  • 进程虚拟地址空间

    千次阅读 2018-11-06 23:19:45
    进程虚拟地址空间的引入  1.程序与进程的区别 程序: 静态 预先编译好的指令和数据的集合 的一个文件 #菜谱 进程:动态 程序运行的过程 #炒菜的过程  2.虚拟地址空间: 程序运行后拥有自己独立的虚拟空间 大小...
  • 进程的虚拟地址在内核中通过三/四级页表到达物理地址。而内核的虚拟地址在NORMAL部分算是逻辑地址只是线性的映射。 这两者有什么关系么?或者说内核态为什么还要有虚拟地址存在? 开场白: 按照以前书上,或...
  • 虚拟地址到物理地址有两种方式:第一、virt_to_phy() 也就是: 虚拟地址 - 3G ; 第二种是通过页表查询的方式; 疑问: 1. 什么时候使用第一种方式,什么时候采用第二种方式? 2. 这两种会不会产生冲突,即两种...
  • 谈起内存管理,首先我们就要搞清楚虚拟地址和物理地址的关系。本文就是简单介绍下这两个基础概念。 物理地址 物理地址指实际存在的物理内存地址,比我有一个2G的内存芯片,那么系统的物理内存就是2G,我要访问该内存...
  • 虚拟地址空间映射到物理地址空间

    千次阅读 2018-09-07 09:06:45
    虚拟地址空间映射到物理地址空间参考如下  当处理器读或写入内存位置时,它会使用虚拟地址。作为读或写操作的一部分,处理器将虚拟地址转换为物理地址。通过虚拟地址访问内存有以下优势:  程序可以使用一系列...
  • 虚拟存储器--虚拟地址与物理地址

    千次阅读 2016-04-07 11:28:06
    虚拟存储器--虚拟地址与物理地址 计算机在运行程序时,需将代码加载入内存中,CPU读取内存中的代码并执行。 早期的计算机在没有引入 虚拟存储器之前,需将整个待运行的程序加载到内存中,因为内存空间...
  • Linux虚拟地址空间

    千次阅读 2018-11-02 21:18:47
    Linux虚拟地址空间 注:本文来自多篇博客整理,具体博客链接在博客下方 在多任务操作系统中,每个进程都运行在属于自己的内存沙盘中。这个沙盘就是虚拟地址空间(Virtual Address Space),在32位模式下它是一个4GB的...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 44,259
精华内容 17,703
关键字:

虚拟地址