《实验三020740309赵玉健.docVIP

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

实验三:Windows线程及其调度观察 一、实验目的: 让同学们了解什么是线程,操作系统是如何调度它们的。 二、实验要求: 程序使用C语言实现。 三、实验过程及程序实现 int main() {  int i;  if (fork() == 0)  {   for (i = 1; i 3; i++)    printf(This is child process\n);  }  else  {   for (i = 1; i 3; i++)    printf(This is parent process\n);  } }   执行结果为: This is child process This is child process This is parent process This is parent process   fork在英文中是“分叉”的意思,这个名字取得很形象。一个进程在运行中,如果使用了fork,就产生了另一个进程,于是进程就“分叉”了。当前进程为父进程,通过fork()会产生一个子进程。对于父进程,fork函数返回子程序的进程号而对于子程序,fork函数则返回零,这就是一个函数返回两次的本质。可以说,fork函数是Unix系统最杰出的成就之一,它是七十年代Unix早期的开发者经过理论和实践上的长期艰苦探索后取得的成果。   如果我们把上述程序中的循环放的大一点: int main() {  int i;  if (fork() == 0)  {   for (i = 1; i 10000; i++)    printf(This is child process\n);  }  else  {   for (i = 1; i 10000; i++)    printf(This is parent process\n);  } }   则可以明显地看到父进程和子进程的并发执行,交替地输出“This is child process”和“This is parent process”。   此时此刻,我们还没有完全理解fork()函数,再来看下面的一段程序,看看究竟会产生多少个进程,程序的输出是什么? int main() {  int i;  for (i = 0; i 2; i++)  {   if (fork() == 0)   {    printf(This is child process\n);   }   else   {    printf(This is parent process\n);   }  } }   exec   在Linux中可使用exec函数族,包含多个函数(execl、execlp、execle、execv、execve和execvp),被用于启动一个指定路径和文件名的进程。   exec函数族的特点体现在:某进程一旦调用了exec类函数,正在执行的程序就被干掉了,系统把代码段替换成新的程序(由exec类函数执行)的代码,并且原有的数据段和堆栈段也被废弃,新的数据段与堆栈段被分配,但是进程号却被保留。也就是说,exec执行的结果为:系统认为正在执行的还是原先的进程,但是进程对应的程序被替换了。   fork函数可以创建一个子进程而当前进程不死,如果我们在fork的子进程中调用exec函数族就可以实现既让父进程的代码执行又启动一个新的指定进程,这实在是很妙的。fork和exec的搭配巧妙地解决了程序启动另一程序的执行但自己仍继续运行的问题,请看下面的例子: char command[MAX_CMD_LEN]; void main() {  int rtn; /* 子进程的返回数值 */  while (1)  {   /* 从终端读取要执行的命令 */   printf();   fgets(command, MAX_CMD_LEN, stdin);   command[strlen(command) - 1] = 0;   if (fork() == 0)   {    /* 子进程执行此命令 */    execlp(command, command);    /* 如果exec函数返回,表明没有正常执行命令,打印错误信息*/    perror(command);    exit(errorno);   }   else   {    /* 父进程,等待子进程结束,并打印子进程的返回值 */    wait(rtn);    printf( child process return %d\n, rtn);   }  } }   这个函数基本上实现了一个shell的功能,它读取用户输入的进程名和参数,并启动对应的进程。   clone   

文档评论(0)

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

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

1亿VIP精品文档

相关文档