实验6进程及进程间的通信之共享内存.doc
文本预览下载声明
实验
实验目的:
实验要求:
熟练使用该节所介绍
实验器材:
软件:
1.安装了的vmware虚拟机
硬件:PC机一台
实验步骤:
API 函数编程一个程序,使之产生一个进程扇:父进程产生一系列子进程,每个子进程打印自己的PID 然后退出。要求父进程最后打印PID。
进程扇process_fan.c参考代码如下:
用进程相关API 函数编写一个程序,使之产生一个进程链:父进程派生一个子进程后,然后打印出自己的PID,然后退出,该子进程继续派生子进程,然后打印PID,然后退出,以此类推。
要求:1) 实现一个父进程要比子进程先打印PID 的版本。(即 打印的PID 一般是递增的)
2 )实现一个子进程要比父进程先打印PID 的版本。(即打印的PID 一般是递减的)
进程链1,process_chain1.c的参考代码如下:
进程链2,process_chain2.c的参考代码如下:
编写程序execl.c,实现父进程打印自己的pid号,子进程调用execl函数,用可执行程序file_creat替换本进程。注意命令行参数。
参考代码如下:
/*execl.c*/
#includeunistd.h
#includestdio.h
#includestdlib.h
int main(int argc,char *argv[])
{
/*判断入参有没有传入文件名*/
if(argc2)
{
perror(you haven,t input the filename,please try again!\n);
exit(EXIT_FAILURE);
}
pid_t result;
result=fork();
if(result0)
{
printf(“I’m parent,my pid:%d, mysun’s pid %d\n”,getpid(), result);
}
/* 下面代码是调用ls程序, 用可执行程序ls替换本进程
if(result==0)
{
printf(“I’m sum process my pid is %d\n”,getpid());
if(execl(/bin/ls,ls,-l,NULL)0)
{
perror(execlp error);
}
}*/
/*下面程序调用execl函数,用可执行程序file_creat替换本进程*/
if(result==0)
{
printf(“I’m sum process my pid is %d\n”,getpid()); if(execl(./file_creat,file_creat,argv[1],NULL)0)
perror(execl error!);
}
}
其中file_creat.c的 代码如下:
file_creat.c
#include stdio.h
#include stdlib.h
#include sys/types.h
#include sys/stat.h
#include fcntl.h
void create_file(char *filename)
{
/*创建的文件具有可读可写的属性*/
if(creat(filename,0666)0)
{
printf(create file %s failure!\n,filename);
exit(EXIT_FAILURE);
}
else
{
printf(create file %s success!\n,filename);
}
}
int main(int argc,char *argv[])
{
/*判断入参有没有传入文件名 */
if(argc2)
{
perror(you havent input the filename,please try again!\n);
exit(EXIT_FAILURE);
}
create_file(argv[1]);
exit(EXIT_SUCCESS);
}
代码分析
execl函数会让一个可执行程序运行并替换本进程,那么这个可执行程序就应该有创建一个文件的功能。我们可以用file_creat.c编译产生的可执行文件file_creat来作为该可执行程序。
运行步骤:
1). 编译应用程序execl.c和file_creat.c
命令:gcc execl.c –o execl
gcc file_creat.c
显示全部