兰州大学操作系统实验五详细答案

  • 格式:docx
  • 大小:1.03 MB
  • 文档页数:20

下载文档原格式

  / 20
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验五

实验名称:

进程管理

实验报告:

实验要求: cat /etc/group (查看组信息)

1.编写一个程序,打印进程的如下信息:进程标识符,父进程标识符,真实用户ID,有效

用户ID,真实用户组ID,有效用户组ID。并分析真实用户ID和有效用户ID的区别。

代码如下:

#include

#include

int main(){

printf("***********\n");

printf("This is the process\n");

printf(" pid=%d\n",getpid());

printf("ppid=%d\n",getppid());

printf(" uid=%d\n",getuid());

printf("euid=%d\n",geteuid());

printf(" gid=%d\n",getgid());

printf("egid=%d\n",getegid());

}

真实用户ID和有效用户ID的区别:

真实用户ID:这个ID就是我们登陆unix系统时的身份ID。

有效用户ID:定义了操作者的权限。有效用户ID是进程的属性,决定了该进程对文件的访问权限.

2.阅读如下程序:

/*process using time */

#include

#include

#include

#include

#include

void time_print(char *,clock_t);

int main(void)

{

clock_t start,end;

struct tms t_start,t_end;

start = times(&t_start);

system(“grep the /usr/doc/*/*> /dev/null2> /dev/null”); // > 将信息放到该文件null中end=times(&t_end); //0 1 2 标准输入标准输出错误输出time_ print(“elapsed”,end-start);

puts(“parent times”);

time _print(“\tuser CPU”,t_end.tms _utime);

time_ print(“\tsys CPU”,t_end.tms_stime);

//获得执行system()的子进程ID

puts(“child times”);

time_print(“\tuser CPU”,t_end.tms_cutime);

time_print(“\tsys CPU”,t_end.tms_cstime);

exit(EXIT_SUCCESS);

}

void time_print(char *str, clock_t time)

{

long tps = sysconf(_SC_CLK_TCK);/*函数sysconf()的作用为将时钟滴答数转化为

秒数,_SC_CLK_TCK 为定义每秒钟有多少个滴答的宏*/

printf(“%s: %6.2f secs\n”,str,(float)time/tps);

}

编译并运行,分析进程执行过程的时间消耗(总共消耗的时间和CPU消耗的时间),并解释执行结果。再编写一个计算密集型的程序替代grep,比较两次时间的花销。注释程序主要语句。

因为该程序计算量很小,故消耗的时间比较少,均为0.00secs 不奇怪。

而更改为计算密集型的之后就较容易观察出消耗时间的差异,如图所示。

3.阅读下列程序:

/* fork usage */

#include

#include

#include

int main(void)

{

pid_t child;

if((child=fork())==-1{

perror(“fork”);

exit(EXIT_FAILURE);

}else if(child==0){

puts(“in child”);

printf(“\tchild pid = %d\n”,getpid()); //取得目前进程的进程ID

printf(“\tchild ppid = %d\n”,getppid());//取得目前进程的父进程ID

exit(EXIT_SUCCESS);

}else{

puts(“in parent”);

printf(“\tparent pid = %d\n”,getpid());

printf(“\tparent ppid = %d\n”,getppid());

}

exit(EXIT_SUCCESS);

}

编译并多次运行,观察执行输出次序,说明次序相同(或不同)的原因;观察进程ID,分析进程ID的分配规律。总结fork()的使用方法。注释程序主要语句。

创建进程ID开始时一般随机分配,但若多次运行,或创建子进程时,会顺序分配内存。此外,当父进程结束时,子进程尚未结束,则子进程的父进程ID变为1,即init fork()的使用方法:

fork()会产生一个新的子进程,其子进程会复制父进程的数据与堆栈空间,如果fork()成功则在父进程会返回新建立的子进程代码(PID),而在新建立的子进程中则返回0。如果fork 失败则直接返回-1,失败原因存于errno中。

在父进程中用fork()创建子进程,通过返回值if语句判断来进行父子进程代码执行。