- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统课程设计 20092103399 李迪
PAGE
PAGE 2
实习题目
指导教师
职 称
学生姓名
学 号
日 期
实习题目
指导教师
职 称
学生姓名
学 号
日 期
内蒙古师范大学计算机与信息工程学院
《操作系统》课程设计报告
实习题目
指导教师
职 称
学生姓名
学 号
日 期
设计题目
编程演示三种存储管理方式的地址换算过程
指导教师
王斯日古楞
职称
姓 名
李迪
学 号
20092103399
日 期
2012/10/18
主要内容要求:
1 设计任务
编程演示三种存储管理方式的地址换算过程
2 设计的功能目标
1、分页方式的地址换算
2、分段方式的地址换算
3、段页式的地址换算
3 设计的思想、方法和技术(含数据结构、算法)
编程演示三种存储管理方式的地址换算过程,分别为分页方式的地址换算,分段方式的地址换算,段页式的地址换算。分页方式通过逻辑地址算出页号与叶内地址,然后通过页表来实现向物理地址的转换。分段方式通过段号和段内地址得到物理地址。段叶式通过段号得到页表首地址,通过页号得到块号,进而得到物理地址。
程序主要有三个功能,分别是分页方式的地址换算,分段方式的地址换算,段页式的地址换算。Switch函数包含4个case语句,分别用page,Segment,SegPagt完成分页方式的地址换算,分段方式的地址换算,段页式的地址换算。
4 设计的主要代码及注释
主函数部分:
int main()
{int code;
int pl,pa,sn,sd,pd,pn;
//const int ptl ;
int temp;
do{
printf(地址换算过程\n\n);
printf( 1.分页式地址换算\n);
printf( 2.分段式地址换算\n);
printf( 3.段页式地址换算\n);
printf( 4.结束运行\n\n);
printf(******本程序由李冬领设计--2010年12月23号*****\n);
printf(\n);
printf(请输入您的选择:);
分页式地址换算部分:
int page(int A,int L)
{
int d,P,kd,i;
int WD;
int PT[256];
for(i=1;i256;i++)
{
PT[i]=rand() %512;//定义随机产生的快号在1到512之间
}
P=A/L;//页号等于逻辑地址/页面大小
d=A%L;//页内地址=逻辑地址%页面大小
if(P=256) printf(页号大于页表长度,越界中断\n\n);//如果页号大于页表长度,输出越界中段
else {
printf(页号=逻辑地址/页面大小=%d,页内地址=逻辑地址%页面大小=%d\n,P,d);//输出页号和页内地址
kd=PT[P];//根据页号随机产生快号
printf(根据页号%d得到块号%d\n,P,kd);
WD=kd*L+d;//计算物理地址的公式
printf(物理地址=块号*页面大小+页内地址\n);
printf(物理地址=%d*%d+%d\n,kd,L,d);//输出物理地址=块号*页面大小+页内地址
printf(逻辑地址%d换算后的物理地址=%d\n\n,A,WD);//输出物理地址的结果
return (0);
}
}
分段式地址换算部分:
nt Segment(int sn,int sd)
{
int i,wd;
for(i=0;i255;i++)
{
st.segf[i]=rand()%255;//定义随机产生段首地址为1到255之间
st.segl[i]=rand()%2048;//定义随机产生段长度为1到2048之间
}
if(sn256) printf(段号%d大于段表长度256,越界中断\n\n,sn);//如果段号大于段表长度,输出越界中断
else if(sdst.segl[sn]) printf(段内地址%d大于段长度%d,越界中断\n\n,sd,st.segl[sn]);//如果段内地址大于段长度,输出越界中断
else{
printf(根据段号找到段首地址%d\n,st.segf[sn]);
printf(物理地址=段首地址+段内地址\n);
printf(物理地址=%d+%d\n,st.segf[sn],sd); //输出物理地址=段首地址+段内地址
wd
您可能关注的文档
最近下载
- 3万吨全粉5万吨法式薯条加工项目可行性研究报告编制格式说明(模板型word).pdf VIP
- 初中物理竞赛试题精选精编第16讲电与磁(含答案与解析).docx VIP
- 第6章 机械振动-改 h(实际4h).ppt
- 2023-2024全国初中物理竞赛试题精选精编第16讲电与磁(解析版).doc VIP
- 2025年全国中小学校党组织书记网络培训示范班在线考试题库及答案.docx VIP
- 中国共产党统一战线工作条例学习PPT课件.pptx VIP
- 前程无忧国企入职题库.pdf VIP
- QCT29106-2004线束标准详细介绍.pdf VIP
- 钠离子电池正极材料的发展与产业化研究.pdf
- 进度控制监理细则.doc VIP
文档评论(0)