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

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
兰州大学操作系统实验五详细答案

实验五 实验名称: 进程管理 实验报告: 实验要求: cat /etc/group (查看组信息) 编写一个程序,打印进程的如下信息:进程标识符,父进程标识符,真实用户ID,有效用户ID,真实用户组ID,有效用户组ID。并分析真实用户ID和有效用户ID的区别。 代码如下: #includeunistd.h #includestdio.h 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是进程的属性,决定了该进程对文件的访问权限. 阅读如下程序: /* process using time */ #includestdio.h #includestdlib.h #includesys/times.h #includetime.h #includeunistd.h 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/null 2 /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 不奇怪。 而更改为计算密集型的之后就较容易观察出消耗时间的差异,如图所示。 阅读下列程序: /* fork usage */ #includeunistd.h #includestdio.h #includestdlib.h 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(

文档评论(0)

haocen + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档