




kok电子竞技权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
kok电子竞技:文档简介
1、操作系统实验kok电子竞技姓名: 学号: 完成时间:2012年11月22日1 / 28目录:实验一:UNIX/LINUIX入门.1 实验二:进程管理.3实验三:线程的管理.10实验四:利用信号实现进程间通信.15实验五:基于消息队列和共享内存的进程间通信.18实验六:一个进程启动另一个程序的执行.23实验一 UNIX/LINUIX入门一、实验目的 了解UNIX/LINUX运行环境,熟悉UNIX/LINUX的常用基本命令,熟悉和掌握UNIX/LINUX下c语言程序的编写、编译、调试和运行方法。二、实验内容1、熟悉UNIX/LINUX的常用基本命令如ls、who、pwd、ps等。2、练习UNIX/LINUX
2、的文本行编辑器vi的使用方法3、熟悉UNIX/LINUX下c语言编译器cc/gcc的使用方法。用vi编写一个简单的显示“Hello,World!”c语言程序,用gcc编译并观察编译后的结果,然后运行它。三、实验要求按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计代码如下:#includevoid main()printf(hello world);五、运行结果1六、收获及机会此次实验让我熟悉了Liunx下的文本行编辑器vi和c语言编译器cc/gcc的使用方法。七、参考资料实验指导书2实验二 进程管理一、实验目的 加深对进程概念的理解,明确
3、进程与程序的区别;进一步认识并发执行的实质二、实验内容(1)进程创建编写一段程序,使用系统调用 fork()创建两个子进程。当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符:父进程显示“a“;子进程分别显示字符”b“和字符“c”。试观察记录屏幕上的显示结果,并分析原因。(2)进程控制修改已编写的程序,将每一个进程输出一个字符改为每一个进程输出一句话,再观察程序执行时屏幕上出现的现象,并分析原因。(3)进程的管道通信编写程序实现进程的管道通信。使用系统调用pipe()建立一个管道,二个子进程P1 和P2 分别向管道各写一句话:Child 1 is sendi
4、ng a message!Child 2 is sending a message!父进程从管道中读出二个来自子进程的信息并显示(要求先接收P1,再接收P2)。三、实验要求 按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计(1)进程创建使用fork()创建两个子进程,父进程等待两个子进程执行完在运行。(2)进程控制使用fork()创建两个子进程,父进程等待两个子进程分别输出一句话在运行。(3)进程的管道通信建立一个管道。在程序中先建立一个子进程,然后向管道中输入数据,然后从子进程中退出到父进程,读出管道数据,然后再建立一个子进程,写入数据
5、,再读出,即可。代码如下:(1) 进程创建:#include #include #include #include #include #include #define INPUT 0#define OUTPUT 13void main() pid_t pid2; /定义两个子进程pid0=fork(); /创建第一个子进程if(pid00) /判断是否创建成功 printf(Fork Failed); exit(-1);else if(pid0 = 0)printf(bn);elsepid1=fork(); /创建另一子进程if(pid10) printf(Fork Failed);exit(
6、-1);else if(pid1 = 0)printf(cn);elsewait(NULL);printf(an); /父进程执行exit(0);(2) 进程控制:#include #include #include #include #include #include 4#define INPUT 0#define OUTPUT 1void main() pid_t pid2;pid0=fork();if(pid00) printf(Fork Failed); exit(-1);else if(pid0 = 0)printf(this is bn);elsepid1=fork();if(pi
7、d10) printf(Fork Failed);exit(-1);else if(pid1 = 0)printf(this is cn);elsewait(NULL);printf(this is an);exit(0);(3) 进程的管道通信5#include #include #include #include #includevoid main()int rw2;/*定义子进程号*/pid_t pid2;int count,count2;/*创建无名管道*/ pipe(rw);char *msg1=child 1 process is sending message!n; 字符串msg
8、1char *msg2=child 2 process is sending message!n; 字符串msg2char buf50,s50;int result;result=pipe(rw);if(result=-1)printf(failed in calling pipe);/*创建子进程*/if(pid0 = fork() = -1) printf(Error in forkn);exit(1);if(pid0 = 0) /printf(child 1 process is sending message!n);/*子进程向父进程写数据,关闭管道的读端*/close(rw0);wr
9、ite(rw1,msg1, 1+strlen(msg1);close(rw1);exit(0); else if(pid1 = fork() = -1) printf(Error in forkn);exit(1);if(pid1 = 0) /printf(child 2 process is sending message!n);/*子进程向父进程写数据,关闭管道的读端*/6close(rw0);write(rw1, msg2, 1+strlen(msg2);close(rw1);exit(0); else/*执行父进程*/printf(in the spawning (parent) pr
10、ocess.n);/*父进程从管道读取子进程写的数据,关闭管道的写端*/close(rw1);count=read(rw0,buf,sizeof(buf);count2=read(rw0,s,sizeof(s);close(rw0);printf(%d %sn,count,buf);printf(%d %sn,count2,s); 五、运行结果 (1)进程创建7 (2)进程控制8(3)进程的管道通信六、收获及机会此次实验让我对进程和管道有了进一步的理解,用fork()创建完子进程后,要用exit()返回父进程,当需要创建两个子进程的时候,不能直接在第一个子进程中直接fork(),要返回到父进程
11、再用fork()再次创建子进程,否则将无法控制。创建完管道后,在向管道中写入数据和从管道中读出数据的时候,要控制好管道的读写控制,不适当的关闭和开启管道端口,将不能使得数据得到正确的读写。这些是我此次实验最大的收获,还需要在今后的时候发现更多的问题,有更深的理解。七、参考资料实验指导书9实验三 线程的管理一、实验目的 编写 Linux 环境下的多线程程序,了解多线程的程序设计方法,掌握最常用的三个函数pthread_create,pthread_join 和pthread_exit 的用法二、实验内容 1、主 程 序 创 建 两 个 线 程 myThread1 和myThread2 , 每个线
12、程打印一句话。使用pthread_create(&id,NULL,(void *) thread,NULL)完成。提示:先定义每个线程的执行体,然后在 main 中()创建几个线程,最后主线程等待子线程结束后再退出。2、创建两个线程,分别向线程传递如下两种类型的参数 传递整型值 传递字符三、实验要求 按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计 先定义2个线程的带有参数的函数,参数分别为整型(int)和字符型(char),每个函数中打印出相对应线程的话。在main函数中,利用pthread_create函数创建该两个线程,在函数参数中
13、的第四位,写入想要传进各进程的参数。最有利用pthread_join等待第二个结束后退出。代码如下:1、主程序创建两个线程 myThread1 和myThread2, 每个线程打印一句话。#include#include#include#includevoid myThread1(void) /线程1printf(this is phread1!n);void myThread2(void) /线程2printf(this is phread2!n);int main(void)10pthread_t id2; int ret;ret=pthread_create(&id0,NULL,(voi
14、d *)myThread1,NULL);if(ret!=0)printf(Create pthread error!n);exit(1);ret=pthread_create(&id1,NULL,(void *)myThread2,NULL);if(ret!=0)printf(Create pthread error!n);exit(1);pthread_join(id0,NULL);pthread_join(id1,NULL);printf(This is the main process.n);return(0);2、创建两个线程,分别向线程传递如下两种类型的参数#include#incl
15、ude#include#includevoid myThread1(void *a)int *num;num=(int*)a;printf(create integer is %dn,*num);11void myThread2( void *b)char *x;x=(char*)b;printf(create char is %cn,*x);int main(void)pthread_t id2;int ret;char c=L;char *a=&c;int test=23;int *attr=&test;ret=pthread_create(&id0,NULL,(void *)myThre
16、ad1,(void*)attr);if(ret!=0)printf(Create pthread error!n);exit(1);pthread_join(id0,NULL);ret=pthread_create(&id1,NULL,(void *)myThread2,(void*)a);if(ret!=0)printf(Create pthread error!n);exit(1);pthread_join(id1,NULL);printf(This is the main process.n);return(0);12五、运行结果1、主程序创建两个线程 myThread1 和myThre
17、ad2, 每个线程打印一句话。2、创建两个线程,分别向线程传递如下两种类型的参数13六、收获及体会此次实验让我对线程的创建有了进一步的理解,在熟练掌握pthread_create和pthread_join两个函数的应用上,进一步明白了如何向进程中传入参数。七、参考资料实验指导书14实验四 利用信号实现进程间通信一、实验目的 学习 UNIX 类操作系统信号机制,编写Linux 环境下利用信号实现进程间通信的方法,掌握注册信号处理程序及signal()调用方法。二、实验内容编写一个程序,完成下列功能:实现一个SIGINT 信号的处理程序,注册该信号处理程序,创建一个子进程,父子进程都进入等待。SI
18、GINT 信号的处理程序完成的任务包括打印接受到的信号的编号和进程PID。编译并运行该程序,然后在键盘上敲Ctrl + C,观察出现的现象,并解释。三、实验要求 按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计创建一个进程,在父子进程中都注册一个用户敲中断键即Ctrl+C的信号处理程序,在子进程中注册一个用户定义信号1,在父进程中注册一个用户定义信号2,然后外部接收信号,最后在main函数中打印出信号的编号和进程PID。在运行时,当用户键入Ctrl+C时,会自动打印出父子进程pid值,但信号的编号始终是父进程中注册的用户定义信号。代码如下
19、:#include#include#include#include#define MAXSTACK 20int stackMAXSTACK;int a=0;int b=0;sem_t sem,sem1;void ReadData1(void)FILE *fp=fopen(1.dat,r);sem_wait(&sem1);int i;for(i=0;i10;i+)fscanf(fp,%d,&stacka+);sem_post(&sem1);sem_post(&sem);fclose(fp);void ReadData2(void)15FILE *fp=fopen(2.dat,r);sem_wai
20、t(&sem1);int i;for(i=0;i8;i+)fscanf(fp,%d,&stacka+);sem_post(&sem1);sem_post(&sem);fclose(fp);void HandleData1(void)int i;sem_wait(&sem);for(i=0;i4;i+)int m=stackb+;int n=stackb+;printf(Plus:%d+%d=%dn,m,n,m+n);void HandleData2(void)int i;sem_wait(&sem);for(i=0;i4;i+)int m=stackb+;int n=stackb+;print
21、f(mul:%d*%d=%dn,m,n,m*n);int main(void)pthread_t t1,t2,t3,t4;sem_init(&sem,0,0);sem_init(&sem1,0,1);pthread_create(&t1,NULL,(void *)HandleData1,NULL);pthread_create(&t2,NULL,(void *)HandleData2,NULL);pthread_create(&t3,NULL,(void *)ReadData1,NULL);pthread_create(&t4,NULL,(void *)ReadData2,NULL);pthr
22、ead_join(t1,NULL);16五、运行结果六、收获及体会此次实验让我学会了在Linux 环境下利用信号实现进程间通信的方法,掌握注册信号处理程序及signal()调用方法,也掌握了接收信号的写法。并在试验中,可通过用户自己输入信号来产生信号的编号,但是通过注册SIGINT信号处理程序打印出的信号编号只是父进程中创建的用户定义信号2,这点还是需要进一步讨论。但总的来说,对利用信号实现进程间的通信,有了更深入的一个了解,收获很大。七、参考资料实验指导书17实验五 基于消息队列和共享内存的进程间通信一、实验目的 Linux系统的进程通信机构(IPC)允许在任意进程间大批量地交换数据。本实验
23、的目的是了解和熟悉:1. Linux支持的消息通信机制及其使用方法2. Linux系统的共享存储区的原理及使用方法。二、实验内容 1.消息的创建、发送和接收 使用消息调用msgget()、msgsnd()、msggrev()、msgctrl()编制长度为1K的消息的发送和接收程序。2.共享存储区的创建、附接和断接使用系统调用shmget()、shmat()、shmctl(),编制一个与上述功能相同的程序。三、实验要求 按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计1.消息队列:先定义一个消息结构,包含消息类型和文本长度。在SERVER函
24、数中,首先获得一个KEY为75的消息的描述符,然后利用do while循环来判断当消息类型为1的时候打印输出。在CLIENT函数中,先获得消息队列,然后利用for循环将消息类型从10赋值到1,发送队列,并打印输出。最后在main函数中调用这两个函数。#include #include #include #include #define MSGKEY 75 struct msgform /*消息结构*/long mtype; /*消息类型*/char mtexe1030; /*文本长度*/ msg;int msgqid,i;void CLIENT( )int i;msgqid=msgget(MS
25、GKEY,0777); /*获得消息的描述符msgqid*/for(i=10;i=1;i-) /*将消息类型由10到1发送*/msg.mtype=i;18printf(client)sentn);msgsnd(msgqid,&msg,1024,0); /*发送消息msg入msgid消息队列*/exit(0);void SERVER( ) msgqid=msgget(MSGKEY,0777|IPC_CREAT); do msgrcv(msgqid,&msg,1030,0,0); /*从队列msgid接受消息msg*/ printf(server)receiven); while(msg.mtyp
26、e!=1); /*消息类型为1时,释放队列*/ msgctl(msgqid, IPC_RMID,0); exit(0);main() if(fork() SERVER();else CLIENT( );wait(0);wait(0);2.共享存储区:先获取共享区,KEY为75,并获得描述符,然后将该共享存储区附接到addr这个虚拟地址上,如消息队列类似,利用while循环从10到1打印输出,并将i值赋给addr。在SERVER中,创建共享存储区,并将起始地址也设置为addr,服务进程共享存储区,所以直接用while循环输出打印“receive”。代码如下:#include#include#in
27、clude#define SHMKEY 75 /*定义共享区关键词*/int shmid,i;int *addr;CLIENT()int i;19shmid=shmget(SHMKEY,1024,0777); /*获取共享区*/addr=shmat(shmid,0,0); /*共享区起始地址为addr*/ for(i=9;i=0;i-)while(*addr!= -1); printf(client)sentn); *addr=i; exit(0);SERVER()shmid=shmget(SHMKEY,1024,0777|IPC_CREAT); addr=shmat(shmid,0,0);
28、do*addr=-1; /*服务进程使用共享区*/while(*addr=-1);printf(server)receivedn); while(*addr);shmctl(shmid,IPC_RMID,0);exit(0);main()if(fork()SERVER();if(fork()CLIENT();wait(0);wait(0);20五、运行结果1消息队列:2、共享存储区:21六、收获及体会此次实验让我对消息队列的获取、传送和共享存储区有了更加深入的了解。理论上来说应该是client和server交替出现,实际上是client先发送了两条,而且最后server接收了2条,但二者分别发
29、送和接收了10条信息,这个和设想是一样的。通过实验我了解到,message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全可能继续睡眠,造成上面现象,在多次send后才receive。共享存储区的运行结构和预想完全吻合,没有疑问。七、参考资料实验指导书22实验六 一个进程启动另一个程序的执行一、实验目的 编写Linux环境下,fork()与exec()的结合使用实现一个进程启动另一个程序的执行的基本方法,掌握exec()的集中调用方法。二、实验内容父进程从终端读取要执行的命令,并交给子进程执行。父进程等待子进程结束,并打印子进程的返回值。提示:从终端读取要执行的命令可用fge
30、ts()实现。三、实验要求 按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验kok电子竞技。四、实验设计 定义一个字符数组来放置命令字符,并用fgets()来实现读取用户输入的命令字符并存入字符数组。用if来判断当用户输入”quit”时,退出当时程序。子程序中调用execlp(),执行成功的话不返回,失败的话返回个-1,并将失败原因打印出来。在父进程中wait等到子进程执行完,然后打印出子进程的返回值。代码如下:#include#include#include#include#include#include#includechar command256;int ma
31、in() int rtn; int errorno; while(1) printf(); fgets(command,256,stdin); /* 从终端读取命令 */ commandstrlen(command)-1=0; if(!strcmp(command,quit)break; /* 当输出quit时退出程序 */ if(fork()=0) /* 子进程执行此命令 */ errorno=execlp(command,command,NULL,NULL); /* 如果exec 函数返回,表明没有正常执行命令,打印错误信息*/23 perror(command); exit(errorn
32、o); else /* 父进程, 等待子进程结束,并打印子进程的返回值 */ wait(&rtn); printf(child process return %dn,rtn); return 0;五、运行结果六、收获及体会此次实验让我对exec类的函数有了一个更深的理解,我知道一个进程一旦调用 exec 类函数,它本身就“死亡”了,系统把代码段替换成新的程序的代码,废弃原有的数据段和堆栈段,并为新程序分配新的数据段与堆栈段,唯一留下的,就是进程号,也就是说,对系统而言,还是同一个进程,不过已经是另一个程序了。同时也学会了fgets()的用法。我写的程序运行后输入命令是不带参数的,由于execlp是这么定义的:int execlp(const char * file,const char * arg,);其中找到符合参数file的文件后,第二个之后的参数当做该文件的argv0,argv1.所以在程序execlp中的后面加入相应的参数即可。七、参考资料实验指导书24
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
kok电子竞技:最新文档
- 小学关于读书的演讲稿(6篇)
- 大学诚信考试演讲稿(6篇)
- 2025年多媒体课件制作:技术进步与教育创新的交汇
- 矿井通风与安全课件《安全部分》第十章火灾防治
- 工作改进的步骤指南
- 办公室接待与来宾信息表
- 人力资源行业人才招聘与培训管理平台
- 2025年广西货运资格考试答案大全
- 夫妻分财产协议书
- 矿山废水防渗漏技术规范
- 总汇-ssat2400必背类比关系总结
- 球墨铸铁管道施工的学习课件
- 学习2022《工业和信息化领域数据安全管理办法(试行)》重点内容PPT课件(带内容)
- 光伏发电场建设工程资料表格(239表格齐全)
- 《纸马》教学设计公开课
- 西服裙缝制工艺课件(PPT 14页)
- 城市道路绿化养护工作
- 国内木材炭化技术专利现状
- 施耐德公司品牌战略
- 校企合作人才培养模式实践研究开题kok电子竞技定稿
- 塑胶原料检验规范
评论
0/150
提交评论