ImageVerifierCode 换一换
格式:DOC , 页数:10 ,大小:1.47MB ,
资源ID:7390272      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/7390272.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(实验三进程创建及简单控制.doc)为本站上传会员【仙人****88】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

实验三进程创建及简单控制.doc

1、 实验三 进程的创建和简单控制 实验目的: 1. 掌握进程的概念和进程的状态,对进程有感性的认识; 2. 掌握进程创建方法; 3. 认识进程的并发执行,了解进程族之间各种标识及其存在的关系; 4. 熟悉进程的创建、阻塞、唤醒、撤销等控制方法。 实验内容: 1. 了解有关Linux进程的属性和进程的层次结构; 2. 学习有关Linux的前台和后台进程; 3. 学习有关Linux命令的顺序执行和并发执行; 4. 学习有关挂起和终止进程; 5. 了解并发程序的不可确定性,进行简单并发程序设计。 实验步骤: (一)Shell 下的进程控制 1. 进入Linux系统。

2、2. 用ps查看进程。 a) linux的ps命令是用来监视系统进程和资源使用情况的命令,可显示 瞬间进程的动态。 b) ps 的参数非常多,常用的参数有: i. -A 列出所有的进程; ii. -w 显示加宽可以显示较多的信息; iii. -au 显示较详细的信息; iv. -aux 显示所有包含其他使用者的进程。 3. 用kill终止某些进程。 a) kill命令通过向进程发送指定的信号来结束进程。 b) 先使用ps查到进程号,再使用kill杀出进程。 4. 用pstree命令显示系统中进程层次结构。 PDF 文件使用 "pdfFactory Pro" 试用版本创建

3、 a) pstree指令用ASCII字符显示树状结构,清楚地表达进程间的相互关 系。 b) 语法格式pstree [-acGhlnpuUV][-H <程序识别码>][<程序识别码 >/<用户名称>] (二)Linux 简单进程编程 1. 理解系统调用fork()的使用。 a) fork()会产生一个与父程序相同的子程序,唯一不同之处在于其进程 号。 图2 系统调用fork() b) 编辑下面的程序,如图3所示,要求实现父进程产生两个子进程,父 进程显示字符“a”、两个子进程,分别显示字符“b”、“c”。 #include main( ) {

4、 int p1,p2; while ((p1=fork())==-1); /*父进程创建第一个进程,直到成功*/ if(p1==0) /*0返回给子进程1*/ { putchar('b');/*P1的处理过程*/ } else ① { /*正数返回给父进程(子进程号)*/ while ((p2=fork())==-1); /*父进程创建第二个进程,直到成功*/ if(p2==0) /*0返回给子进程2*/ { putchar('c');/*P2的处理过程*/ } else { putchar('a');/*P2创建完成后,父进程的处理过程*/ } } }

5、 图3 系统调用fork()的使用示例一 思考: i. 编译连接通过后,多次运行程序,观察进程并发执行结果,并分析 原因。 ii. 删除语句①,观察输出的内容,体会fork的使用。 2. 将上述的输出字符改为输出较长的字符串,如图5所示。 #include int main( ) { int p1,p2; while ((p1=fork())== -1); /*父进程创建第一个进程,直到成功*/ if(p1==0) /*0返回给子进程1*/ printf("boy\n"); /*P1的处理过程*/ else { /*正数返回给父

6、进程(子进程号)*/ while ((p2=fork())==-1); /*父进程创建第二个进程,直到成功*/ if(p2 == 0) /*0返回给子进程2*/ printf("daughter\n"); /*P2的处理过程*/ else printf("parent\n"); /*P2创建完成后,父进程的处理过程*/ } } 图4 系统调用fork()的使用示例二 思考: i. 编译连接通过后,多次运行程序,观察进程并发执行结果: ii. 如果多次运行输出内容没有变化,请分析原因。 iii. 并改写原程序,延长每个进程的执行时间,再次观察运行情况。 3. 将

7、上述的输出字符改为多条输出语句,如图6所示。 #include PDF 文件使用 "pdfFactory Pro" 试用版本创建 main( ) { int p1,p2; int i; while ((p1=fork())==-1); /*父进程创建第一个进程,直到成功*/ if(p1==0) /*0返回给子进程1*/ for( i =0; i < 1000; i++) /*P1的处理过程*/ {putchar('b'); } else{ /*正数返回给父进程(子进程号)*/ while ((p2=fork())==-1); /*父进程创建第二个进程,

8、直到成功*/ if(p2==0) /*0返回给子进程2*/ for( i =0; i < 1000; i++) {putchar('c'); } /*P2的处理过程*/ else for( i =0; i < 1000; i++) {putchar('a'); } /*P2创建完成后,父进程的处理过 程*/ } } 图5 系统调用fork()的使用示例三 思考: i. 编译连接通过后,多次运行程序,观察进程并发执行结果: ii. 如果多次运行输出内容没有变化,请分析原因。并改写原程序,延 长每个进程的执行时间,再次观察运行情况。 iii. 如果多次运行

9、输出内容发生变化,并分析原因。 iv. 将进程放在后台运行,用pstree观察进程的宗族关系。 v. 系统创建一个新进程(使用系统调用fork)与让系统执行一个新程 序(使用系统调用exec)有什么差异? 4. 理解系统调用wait( )、getpid( )和getppid( )的使用。程序代码如图6 所示。 #include #include #include #include #include #include #includ

10、e int main() { char buf[100]; pid_t cld_pid; int fd; if((fd=open("temp",O_CREAT|O_TRUNC|O_RDWR,S_IRWXU))==-1) { printf("open error%d",errno); exit(1); } strcpy(buf,"This is parent process write\n"); if((cld_pid=fork())==0) { /*这里是子进程执行的代码*/ strcpy(buf,"This is child process w

11、rite\n"); printf("This is child process\n"); sleep(1); printf("My PID (child) is%d\n",getpid()); /*打印出本进程的ID*/ sleep(1); printf("My parent PID is %d\n",getppid()); /*打印出父进程的ID*/ sleep(1); write(fd,buf,strlen(buf)); close(fd); exit(0); } else { /*这里是父进程执行的代码*/ wait(0); /*如果此处没有这一句会如何?*/

12、 printf("This is parent process\n"); sleep(1); printf("My PID (parent) is %d\n",getpid()); /*打印出本进程的ID*/ sleep(1); printf("My child PID is %d\n",cld_pid); /*打印出子进程的ID*/ sleep(1); write(fd,buf,strlen(buf)); close(fd); } return 0; } 图6 系统调用wait()的使用 思考: i. 编译连接通过后,多次运行程序,观察进程并发执行结果: ii

13、 语句sleep(1);起什么作用?删除所有sleep(1);语句,并观察运行结果; iii. 删除wait(0);语句,并观察运行结果,并请分析两次结果不同的原因, 理解wait 的作用。 进程调用了wait以后就开始阻塞自己,wait开始寻找一个已经变成僵尸的子进程,找到后收集该子进程的信息,并把它删除后再返回,如果没有出现这样的子进程,那么就会一直等待。 5. 编写程序创建子进程。父子进程分别打印自己和父进程的进程ID,要求每3 秒钟打印系统进程信息,重复5次后退出。父进程待子进程结束后退出。提 示: A、用系统调用getpid和getppid获取进程ID; B、用系统

14、调用fork进程创建; C、用系统调用wait 控制父子进程同步; D、用库函数system实现在一个进程内部运行另一个进程,即创建一个新进 程; E、Shell命令"/bin/ps"作为system的字符串参数,实现打印系统进程信息。 #include #include #include #include #include #include #include #include

15、int main() { int p1; int i; while((p1=fork())==-1); if(p1==0) { wait(0); for(i=1;i<=5;i++) { printf("My PID(child) is%d\n",getpid()); printf("My parent ID is%d\n",getppid()); sleep(5); } } else { for(i=1;i<=5;i++) { printf("My PID(parent) is%d\n",getpid()); sleep(5); } exit(0); } }

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服