高级操作系统——Nachos进程管理

Exercise 1 调研
调研Linux或Windows中进程控制块(PCB)的基本实现方式,理解与Nachos的异同。
答案:
linux:利用task_struct来描述数据结构
windows:利用EPROCESS、KPROCESS、PEB来描述。
功能齐全,主要有以下:
1:进程描述信息
• 进程标识符(process ID) ,唯一,通常是一个整数
• 进程名,通常基于可执行文件名(不唯一)
• 用户标识符(user ID) ;进程组关系
2:进程控制信息
• 当前状态
• 优先级(priority)
• 代码执行入口地址
• 程序的磁盘地址
• 运行统计信息(执行时间、页面调度)
• 进程间同步和通信;阻塞原因
• 进程的队列指针
• 进程的消息队列指针
•3:所拥有的资源和使用情况
• 虚拟地址空间的现状
• 打开文件列表
4: CPU 现场信息
• 寄存器值(通用、程序计数器PC 、状态PSW ,地址
如栈指针)
• 指向赋予该进程的段/ 页表的指针

相比之下,nachos没有单独完整的数据结构来描述进程,仅有一个thread对象来描述线程,拥有的属性有name 线程名,stackTop 线程栈顶,stack 线程栈,status 线程状态

Exercise 2 源代码阅读
仔细阅读下列源代码,理解Nachos现有的线程机制。
 code/threads/main.cc和code/threads/threadtest.cc
 code/threads/thread.h和code/threads/thread.cc

主要的cc为:
main.cc:
1:调用(void) Initialize(argc, argv)初始化线程
2:调用ThreadTest();进程线程测试
3:利用int argc, char **argv执行一系列判断操作,根据输入执行不同的操作

system.cc:
1:Initialize()初始化方法:根据int argc, char **argv执行操作,并创建一个新线程 currentThread = new Thread(“main”);
thread.cc:
2:Thread构造方法和析构方法
3:Fork() `

StackAllocate(func, arg);  //分配堆栈,执行方法
IntStatus oldLevel = interrupt->SetLevel(IntOff); //关闭中断状态
scheduler->ReadyToRun(this);	// 将这个线程加入到readlist中去,即放入就绪队列
(void) interrupt->
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值