北京工业大学操作系统实验报告Word格式文档下载.docx
- 文档编号:16310645
- 上传时间:2022-11-22
- 格式:DOCX
- 页数:24
- 大小:351.95KB
北京工业大学操作系统实验报告Word格式文档下载.docx
《北京工业大学操作系统实验报告Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《北京工业大学操作系统实验报告Word格式文档下载.docx(24页珍藏版)》请在冰豆网上搜索。
”c语言程序,用gcc编译并观察编译后的结果,然后运行它。
三、实验要求
按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,并写出实验报告。
四、实验设计
代码如下:
#include<
>
intmain(){
printf("
Hello,world"
);
return0;
}
五、运行结果
六、收获及机会
此次实验让我熟悉了c语言编译器cc/gcc的使用方法。
七、参考资料
《实验指导书》
实验二进程管理
加深对进程概念的理解,明确进程与程序的区别;
进一步认识并发执行的实质
(1)进程创建
编写一段程序,使用系统调用fork()创建两个子进程。
当此程序运行时,在系统中有一
个父进程和两个子进程活动。
让每一个进程在屏幕上显示一个字符:
父进程显示“a“;
子进
程分别显示字符”b“和字符“c”。
试观察记录屏幕上的显示结果,并分析原因。
(2)进程控制
修改已编写的程序,将每一个进程输出一个字符改为每一个进程输出一句话,再观察程
序执行时屏幕上出现的现象,并分析原因。
(3)进程的管道通信
编写程序实现进程的管道通信。
使用系统调用pipe()建立一个管道,二个子进程P1和
P2分别向管道各写一句话:
Child1issendingamessage!
Child2issendingamessage!
父进程从管道中读出二个来自子进程的信息并显示(要求先接收P1,再接收P2)。
按照要求编写程序,放在相应的目录中,编译成功后执行,并按照要求分析执行结果,
并写出实验报告。
使用fork()创建两个子进程,父进程等待两个子进程执行完在运行。
使用fork()创建两个子进程,父进程等待两个子进程分别输出一句话在运行。
建立一个管道。
在程序中先建立一个子进程,然后向管道中输入数据,然后从子进程中退出到父进程,读出管道数据,然后再建立一个子进程,写入数据,再读出,即可。
(1)进程创建:
voidmain(){
intpid1,pid2;
pid1=fork();
if(pid1<
0){
Fork1failed!
!
"
}
if(0==pid1){
b"
exit(0);
if(pid1>
0){
wait(NULL);
pid2=fork();
if(pid2<
Fork2failed!
if(0==pid2){
c"
if(pid2>
a"
(2)进程控制:
thisischildb\n"
thisischildc\n"
fathera\n"
sys/>
intpfd[2];
char*msg1="
;
char*msg2="
charbuf[256];
intr,w;
if(pipe(pfd)<
0){
pipecreateerror!
\n"
exit
(1);
}
close(pfd[0]);
n"
voidmyThread2(void){
Thisispthread2.\n"
intmain(void){
pthread_tid1,id2;
intret1,ret2;
ret1=pthread_create(&
id1,NULL,(void*)myThread1,NULL);
if(0!
=ret1){
Createpthread1error!
ret2=pthread_create(&
id2,NULL,(void*)myThread2,NULL);
=ret2){
Createpthread2error!
exit
(2);
pthread_join(id1,NULL);
pthread_join(id2,NULL);
return(0);
2、创建两个线程,分别向线程传递如下两种类型的参数
void*myThread1(void*arg){
int*num;
num=(int*)arg;
createparameteris%d.\n"
*num);
return(void*)0;
void*myThread2(void*arg){
char*ch;
ch=(char*)arg;
createparameteris%c.\n"
*ch);
intnum=1;
charch='
a'
int*p_num=&
num;
char*p_ch=&
ch;
id1,NULL,myThread1,(void*)p_num);
id2,NULL,myThread2,(void*)p_ch);
1、主程序创建两个线程myThread1和myThread2,每个线程打印一句话。
六、收获及体会
此次实验让我对线程的创建有了初步的理解,在熟练掌握pthread_create和pthread_join两个函数的应用上,学会了如何向线程中传入参数。
实验四利用信号实现进程间通信
学习UNIX类(SystemV)操作系统信号机制,编写Linux环境下利用信号实现进程间通信的方法,掌握相关系统调用的使用方法。
创建4个线程,其中两个线程负责从文件读取数据到公共的缓冲区,另两个线程从缓冲区读取数据作不同的处理(加和乘运算)。
使用信号量控制这些线程的执行。
4个线程,两个生产者两个消费者;
3个信号量:
信号量n确保消费者不会从空的缓冲区取数;
信号量S确保所有参与者之间互斥对缓冲区操作(防止出现两个生产者同时向一个缓冲区部分写,或写的同时有消费者来读的情况);
信号量e确保缓冲区满后不会再向其中写。
两个生产者分别从两个文件中读取数据写到缓冲区,两个消费者分别做“+”和“*”操作
#defineDATA1"
#defineDATA2"
#defineMAX_BUFFER5
intin=0;
intout=0;
intcount1=0;
intcount2=0;
intnum_buffer[MAX_BUFFER];
sem_tn;
sem_ts;
sem_te;
void*produceThread1(FILE*fp1){
intnum;
while(fscanf(fp1,"
%d"
&
num)!
=EOF){
sem_wait(&
e);
s);
produceThread1put%dinbuffer[%d].\n"
num,in);
num_buffer[in]=num;
in++;
in=in%MAX_BUFFER;
sem_post(&
n);
void*produceThread2(FILE*fp2){
while(fscanf(fp2,"
produceThread2put%dinbuffer[%d].\n"
void*consumeThread3(){
intnums[2];
intresult;
while
(1){
nums[count1]=num_buffer[out];
consumeThread3Get%dfrombuffer[%d].\n"
nums[count1],out);
out++;
out=out%MAX_BUFFER;
count1++;
if(2==count1){
result=nums[0]+nums[1];
%d+%d=%d.\n"
nums[0],nums[1],result);
count1=0;
void*consumeThread4(){
nums[count2]=num_buffer[out];
consumeThread4Get%dfrombuffer[%d].\n"
nums[count2],out);
count2++;
if(2==count2){
result=nums[0]*nums[1];
%d*%d=%d.\n"
count2=0;
intret1,ret2,ret3,ret4;
pthread_tid1,id2,id3,id4;
sem_init(&
n,0,0);
s,0,1);
e,0,MAX_BUFFER);
FILE*fp1=NULL;
FILE*fp2=NULL;
fp1=fopen(DATA1,"
r"
fp2=fopen(DATA2,"
if(NULL==fp1){
if(NULL==fp2){
id1,NULL,produceThread1,fp1);
id2,NULL,produceThread2,fp2);
ret3=pthread_create(&
id3,NULL,consumeThread3,NULL);
=ret3){
Createpthread3error!
exit(3);
ret4=pthread_create(&
id4,NULL,consumeThread4,NULL);
=ret4){
Createpthread4error!
exit(4);
pthread_join(id3,NULL);
pthread_join(id4,NULL);
fclose(fp1);
fclose(fp2);
此次实验让我实践了在Linux环境下利用信号量实现生产者消费者问题的解决,掌握了信号量相关函数的使用方法。
实验五基于消息队列和共享内存的进程间通信
Linux系统的进程通信机构(IPC)允许在任意进程间大批量地交换数据。
本实验的目的是了解和熟悉:
1.Linux支持的消息通信机制及其使用方法
2.Linux系统的共享存储区的原理及使用方法。
1.消息的创建、发送和接收
使用消息调用msgget()、msgsnd()、msggrev()、msgctrl()编制长度为1K的消息的发送和接收程序。
2.共享存储区的创建、附接和断接
使用系统调用shmget()、shmat()、shmctl(),编制一个与上述功能相同的程序。
1.消息队列:
先定义一个消息结构,包含消息类型和文本长度(1024)。
在主函数中,首先获得一个KEY为75的消息的描述符,然后在client子进程中连续发消息类型为10~1的十条消息。
然后在server子进数中,用while(i!
=1)循环接受消息,以i==1作为结束条件。
接受完后撤销消息队列。
#include<
#defineMAX1024
structmymsg{
longintmymsgtype;
chartext[MAX];
}msg;
intmsgid;
inti=1;
pid_tpid_client;
pid_tpid_server;
msgid=msgget(75,0777|IPC_CREAT);
d)(type:
%d)\n"
i,;
i++;
msgsnd(msgid,&
msg,MAX,0);
}else{
d)(type:
11-i,i);
msgctl(msgid,IPC_RMID,0);
wait(0);
享存储区:
在主进程中先建立共享存储区,KEY为75,并获得描述符,然后将该共享存储区附接到virtual_address这个虚拟地址上,在client子进程中利用while循环从10到1打印输出,并将i值赋给virtual_address[i]。
在server子进程中,循环取出virtual_address[i]中的内容并打印输出。
最后在主程序中断开附接,并撤销共享存储区。
#defineKEY75
intmain(){
intid,i,pid_server,pid_client;
char*virtual_address;
id=shmget(KEY,sizeof(char)*MAX,IPC_CREAT|0777);
//createashm
virtual_address=shmat(id,0,0);
//returntoaddressoftheshm(fujie)
if((pid_server=fork())==-1){
Forkserverfailed!
if(pid_server==0){
sleep
(1);
for(i=0;
i<
=10;
i++)
Serverreceived%d\n"
virtual_address[i]);
if((pid_client=fork())==-1){
errorinforka\n"
if(pid_client==0){
i=0;
while
(1){
virtual_address[i]=i;
Clientsent%d\n"
if(virtual_address[i]==10)
break;
shmdt(virtual_address);
//duankailianjie
shmctl(id,IPC_RMID,0);
1消息队列:
2、共享存储区:
此次实验让我对消息队列的获取、消息的传送和共享存储区有了初步的了解。
实验六一个进程启动另一个程序的执行
编写Linux环境下,fork()与exec()的结合使用实现一个进程启动另一个程序的执行的基本方法,掌握exec()的集中调用方法。
父进程从终端读取要执行的命令,并交给子进程执行。
父进程等待子进程结束,并打印子进程的返回值。
提示:
从终端读取要执行的命令可用fgets()实现。
在主进程中定义一个字符数组来放置命令字符,并用fgets()来实现从键盘终端读取用户输入
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 北京工业大学 操作系统 实验 报告
![提示](https://static.bdocx.com/images/bang_tan.gif)