请简述动态可重定位分区分配的主要工作流程。 分区式分配又分为:固定式分区、可变式分区、可重定位分区和多重分区4种管理方案。固定式分区1.实现原理固定式分区是在处理作业之前存储器就已经被划分成若干个分区,每个分区的大小可以相同,也可以不同。但是,一旦划分好分区后,主存储器中的分区的个数就固定了,且每个分区的大小固定不变。2.硬件支持采用这种存储管理方案只需要很少一点专用硬件,即存储保护机构,以防止某一个作业干扰或破坏操作系统和其他作业。有两种实现方法:其一,使用两个界限寄存器框住正在使用的内存区域,但是这样做很麻烦,每当重新分配处理机时都得修改界限寄存器的内容。其二,为每个分区配上一个单独的保护锁,程序状态字中有一把钥匙,根据锁和钥匙相匹配的方法来实现存储保护。3.软件算法这种分区方式一般将内存的用户区分成大小不等的分区,以适应不同大小作业的需要。系统中有一张分区说明表,每个表目记录一个分区的大小、起始地址和分区的状态,当系统为某个作业分配主存空间时,根据所需要的内存容量,在分区表中找到一个足够大的空闲分区分配给它,然后将此作业装入内存。如果找不到足够大的空闲分区,则这个作业暂时无法分配内存空间,系统将调度另一个作业。当一个。
分区存储管理中常用哪些分配策略 一、固定分区存储管理其基本思想是将内存划分成若干固定大小的分区,每个分区中最多只能装入一个作业。当作业申请内存时,系统按一定的算法为其选择一个适当的分区,并装入内存运行。由于分区大小是事先固定的,因而可容纳作业的大小受到限制,而且当用户作业的地址空间小于分区的存储空间时,造成存储空间浪费。1、空间的分配与回收系统设置一张“分区分配表”来描述各分区的使用情况,登记的内容应包括:分区号、起始地址、长度和占用标志。其中占用标志为“0”时,表示目前该分区空闲;否则登记占用作业名(或作业号)。有了“分区分配表”,空间分配与回收工作是比较简单的。2、地址转换和存储保护固定分区管理可以采用静态重定位方式进行地址映射。为了实现存储保护,处理器设置了一对“下限寄存器”和“上限寄存器”。当一个已经被装入主存储器的作业能够得到处理器运行时,进程调度应记录当前运行作业所在的分区号,且把该分区的下限地址和上限地址分别送入下限寄存器和上限寄存器中。处理器执行该作业的指令时必须核对其要访问的绝对地址是否越界。3、多作业队列的固定分区管理为避免小作业被分配到大的分区中造成空间的浪费,可采用多作业队列的方法。。
18,什么叫重定位?采用内存分区管理时如何实现程序运行时的动态重定位?所谓地址重定位就是当一个程序装入到与其地址不一致的存储空间时而进行地址调整过程。。
根据内存分区方式的不同,内存分区可有()分区、()分区和动态重定位分区三种。
可重定位分区分配和可重定位装入方式有什么不同? 一个是程序装入内存时要把程序里表示地址的数据加上一个基值(程序装入地址),是多道系统的产物,单道程序直接装入内存0地址就好了,另一个是分配内存时把内存中多个程序段紧凑在一起,避免”外零头“浪费内存。两者的操作都是重定位,所以方法是一样的,都是调整程序中的地址,但分属于两个过程。举个例子,要运行程序段A,但内存中的空内存段都比A小,这时要对内存中的其他程序进行重定位,紧凑内存,再为A分配内存,这就是重定位分配内存,分配完要把A装入内存这里是重定位装入。到考研网网站查看回答详情>;>;
操作系统中的动态重定位和静态重定位? 静态重定位:即在程2113序装入内存的5261过程中完成,是指在程序开始运行前,程4102序中的各个地址有关的1653项均已完成重定位,地址变换通常是在装入时一次完成的,以后不再改变,故称为静态重定位。动态重定位:它不是在程序装入内存时完成的,而是CPU每次访问内存时 由动态地址变换机构(硬件)自动进行把相对地址转换为绝对地址。动态重定位需要软件和硬件相互配合完成。扩展资料在装入程序前,系统会计算未使用的内存,然后将程序装入,并记下开始地址。在执行有相对地址的指令时,会将所有的地址加个刚才记下的开始地址,就叫重定位。程序放在不连续的实际物理空间中,要进行逻辑地址到物理地址的转换,实现动态重定位一般需要段页式存储管理,页式存储管理用的不是寄存器,使用的是称为page table(页表)的数据结构page table记录了所有逻辑地址到物理地址的转换信息,进程切换的时候需要冲洗硬件上的page table。参考资料来源:-动态重定位参考资料来源:-重定位
动态重定位分区管理如何实现虚实地址映射 作业装入内存时,是将该用户的程序和数据原封不动地装入到内存中。当调度该进程在cpu上执行时,操作系统就自动将该进程在内存的起始地址装入基址寄存器,将进程的大小装入限长寄存器当执行指令时,如果地址合法,则将相对地址与基址寄存器中的地址相加,所得结果就是真正要访问的内存地址;如果地址越界,则发出相应中断,进行处理。
什么是重定位?重定位有哪几种类型2为什么要进行重定位? 1.什么是重定位?由于一个作业装入到与其地址空间不一致的存储空间,对有关地址部分的调整过程称为重定位。2.重定位有哪几种类型?分为静态重定位和动态重定位两种类型。3.为什么要进行重定位?我们写正常程序的时候根本不用去关心变量(常量)的位置,因为源程序在编译的时候它的内存中的位置郡被计算好了。程序装入内存时,系统不会为它重定位。我们需要用到变量(常量)的时候直接用变量名访问它就行了。有的程序不可避免也要用到变量(常量),各个变量(常量)在内存中的位置自然也不相同。既然这些变量没有固定的地址,那么程序在运行的过程中只有重定位,才可以正常地访问相关资源。
静态地址重定位跟动态地址重定位的区别? 静态重定位和动2113态重定位的区别:①静态重定位是5261在作4102业装入的时候一次完成,动态重定位1653是在作业执行时再实现的。②静态重定位是软件支持的,动态重定位是硬件和软件 合作实现的。③静态重定位不能实现主存的移动,而动态重定位可以。④动态重定位还可能 提供虚拟存储空间。
可重定位内存分区分配目的为(25)。A.解决碎片问题B.便于多作业共享内存C.回收空白区方便D.摆脱用