操作系统实验报告 下载本文

内容发布更新时间 : 2024/6/27 3:06:06星期一 下面是文章的全部内容请认真阅读。

课程设计(综合实验)报告

( 2014-- 2015年度第一学期)

名 称: 操作系统综合实验 题 目: OS lab 综合实验 院 系: 计算机系 班 级: 计科1202 学 号: 学生姓名:

指导教师: 赵文清 王新颖 设计周数: 第八、九周 成 绩:

日期:2014 年 10月29日

实验3 进程的创建

一、 实验目的

练习使用EOS API函数CreateProcess创建一个进程,掌握创建进程的方法,理解进程和程序的区别。

调试跟踪CreateProcess函数的执行过程,了解进程的创建过程,理解进程是资源分配的单位。 二、 实验内容 1 准备实验

2 练习使用控制台命令创建EOS应用程序的进程

3 练习通过编程的方式让应用程序创建另一个应用程序的进程 4 调试CreateProcess函数 5 调试PsCreateProcess函数

6 练习通过编程的方式创建应用程序的多个进程 三、问题答案及参考代码

1. 在源代码文件提供的源代码基础上进行修改,要求使用同时创建10个进程。提示:可以使用PROCESS_INFORMATION类型定义一个有10个元素的数组,每一个元素对应一个进程。使用一个循环创建10个子进程,然后再使用一个循环等待10个子进程结束,得到退出码后关闭句柄。

STARTUPINFO StartupInfo;

PROCESS_INFORMATION ProcInfo[10]; ULONG ulExitCode;

INT nResult=0;。 int i,j;.\\n\\n\

= GetStdHandle(STD_INPUT_HANDLE); = GetStdHandle(STD_OUTPUT_HANDLE); = GetStdHandle(STD_ERROR_HANDLE); for(i =0; i < 10; i++)

if(CreateProcess(\]));

else {

for(j = 0; j < i; j++){

WaitForSingleObject(ProcInfo[j].ProcessHandle, INFINITE);

GetExitCodeProcess(ProcInfo[j].ProcessHandle,

&ulExitCode); printf(\process %d exit with %d.\\n\

CloseHandle(ProcInfo[j].ProcessHandle);

CloseHandle(ProcInfo[j].ThreadHandle); }

printf(\

GetLastError()); nResult = 1;

return nResult; }

for(i=0;i<10;i++){

WaitForSingleObject(ProcInfo[i].ProcessHandle, INFINITE);

GetExitCodeProcess(ProcInfo[i].ProcessHandle, &ulExitCode); } for(i=0i<10;i++){

printf(\CloseHandle(ProcInfo[i].ProcessHandle);

CloseHandle(ProcInfo[i].ThreadHandle); }

return nResult; }

3. 在PsCreateProcess函数中调用了PspCreateProcessEnvironment函数后又先后调用了PspLoadProcessImage和PspCreateThread函数,学习这些函数的主要功能。能够交换这些函数被调用的顺序吗思考其中的原因。

PspCreateProcessEnvironment 的主要功能是创建进程控制块,并且为进程创建了地址空间和分配了 句柄表。PspLoadProcessImage 是将进程的可执行映像加载到了进程的地址空间中。PspCreateThread 创建了进程的主线程。这三个函数被调用的顺序是不能够改变的。就向上面描述的加载可执行映像之前必须已经为进程创建了地址空间,这样才能够确定可执行映像可以被加载到内存的什么位置。在创建主线程之 前必须已经加载了可执行映像,这样主线程才能够知道自己要从哪里开始执行,执行哪些指令。因此不能交换他们的顺序。

实验4 线程的状态和转换

一、 实验目的

调试线程在各种状态间的转换过程,熟悉线程的状态和转换。 通过为线程增加挂起状态,加深对线程状态的理解。 二、 实验内容 1 准备实验

2 调试线程状态的转换过程(阻塞—就绪、运行—就绪、就绪—运行、运行—阻塞) 3 为线程增加挂起状态

三、问题答案及参考代码

PsResumThread(IN HANDLE hThread){

STATUS Status; BOOL IntState; PTHREAD Thread;

Status=ObRefObjectByHandle(hThread,PspThreadType,(PVOID*)&Thread); if (EOS_SUCCESS(Status)){

IntState = KeEnableInterrupts(FALSE);

if (Zero == Thread->State) {

ListRemoveEntry(&Thread->StateListEntry); PspReadyThread(Thread); PspThreadSchedule(); Status = STATUS_SUCCESS;} else{

Status = STATUS_NOT_SUPPORTED; }

KeEnableInterrupts(IntState);考一下,在本实验中,当

loop线程处于运

行状态时,EOS中还有哪些线程,它们分别处于什么状态。可以使用控制台命令pt查看线程的状态。

2.当loop线程在控制台1中执行,并且在控制台2中执行suspend命令时,为什么控制台1中的loop线程处于就绪状态而不是运行状态

答:当在控制台2 中执行suspend命令时,实质上是优先级为24的控制台2线程抢占了处理器,也就是控制台2线程处于运行状态,所以此时loop线程处于就绪状态了。

4. 总结一下在图5-3中显示的转换过程,哪些需要使用线程控制块中的上下文(将线程控制块中的上下文恢复到处理器中,或者将处理器的状态复制到线程控制块的上下文中),哪些不需要使用,并说明