实验五 实验名称: 进程管理 实验报告: 实验要求: 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/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 ...