Python|分页管理方式下存储分配情况模拟

2023-10-20 18:10

本文主要是介绍Python|分页管理方式下存储分配情况模拟,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

介绍

  1. 现有一信息量为5页的作业要装入,运行分配程序,为作业分配主存且建立页面,之后运行回收程序。过程中打印分配与回收前后位示图和空闲块数
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  2. 有一作业执行结束,它占用的块号为第4,5,6,31块,运行回收程序,回收作业,归还主存块。打印回收前后位示图和空闲块数。在这里插入图片描述
  3. 当装入一个作业时,当前空闲块数不能满足作业需求则分配失败在这里插入图片描述

相关阅读

Python|页面置换模拟程序设计
Python|银行家算法
Python|独占设备的分配和回收模拟
Python|模拟文件系统
Python|进程调度算法
Python|分页管理方式下存储分配情况模拟
Python|Windows下实现经典进程同步问题——理发师问题
Python|模拟实现动态分区存储管理

完整代码

import numpy
from collections import Countermain_memory = numpy.asarray([[1, 1, 0, 0, 1, 1, 1, 0],[0, 1, 0, 1, 0, 1, 0, 0],[0, 0, 0, 0, 0, 0, 0, 0],[1, 0, 0, 0, 0, 0, 0, 1],[0, 0, 0, 0, 0, 0, 0, 0],[0, 0, 0, 0, 0, 0, 0, 0],[0, 0, 0, 0, 0, 0, 0, 0],[0, 0, 0, 0, 0, 0, 0, 0],
])page_table = []def current_free_blocks():# 查找当前空闲块数counts = Counter(main_memory.flatten())return counts[0]def is_need(need):# 当前空闲块数是否能满足作业要求if need > current_free_blocks():return Falseelse:return Truedef bolck_number(i, j):# 块号return i * 8 + jdef byte_number(block_number):# 字节号j = block_number // 8return jdef digits(block_number):# 位数i = block_number % 8return idef show_page_table(page_table):# 输出页表print('----------------------页表------------------------')print('页号\t|块号')for i in range(len(page_table)):print('{}\t|{}'.format(i, page_table[i]))print('-------------------------------------------------')def show_bitmap():for i in main_memory:print(i)def allocate_space(pages):# 分配空间print('开始分配……')for i in range(8):for j in range(8):if main_memory[i][j] == 0:main_memory[i][j] = 1page_table.append(bolck_number(i, j))pages -= 1if pages == 0:breakif pages == 0:breakprint('分配成功!')def free_space(page_table):# 回收空间print('开始回收……')for i in page_table:main_memory[byte_number(i)][digits(i)] = 0print('回收成功!')def load():# 装入作业print('当前空闲块数:', current_free_blocks())pages = int(input('请输入要装入作业的页数:'))print('-------------------------------------------------')if not is_need(pages):print('当前空闲块数不能满足作业要求,分配失败!\n')returnelse:print('-------------------分配前的位示图-------------------')show_bitmap()print('-------------------------------------------------')allocate_space(pages)show_page_table(page_table)print('分配后空闲块数:', current_free_blocks())print('-------------------分配后的位示图-------------------')show_bitmap()print('-------------------------------------------------')print('-------------------回收前的位示图-------------------')show_bitmap()print('-------------------------------------------------')free_space(page_table)print('回收后空闲块数:', current_free_blocks())print('-------------------回收后的位示图-------------------')show_bitmap()print('-------------------------------------------------')def sample():# 执行文档中的示例,回收一个占用的块号为第4,5,6,31块的作业print('当前空闲块数:', current_free_blocks())sample_page_table = [4, 5, 6, 31]show_page_table(sample_page_table)print('-------------------回收前的位示图-------------------')show_bitmap()print('-------------------------------------------------')free_space(sample_page_table)print('回收后空闲块数:', current_free_blocks())print('-------------------回收后的位示图-------------------')show_bitmap()print('-------------------------------------------------')
# sample()
load()

这篇关于Python|分页管理方式下存储分配情况模拟的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/248819

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同