里奴性进程控制实验报告
实验名称: Linux进程控制
实验要求:一.编写一个Linux系统C程序,由父亲创建2个子进程,再由子进程各自从控制台接收一串字符串,保存在各自的全局字符串变量中,然后正常结束。父进程调用waitpid等待子进程结束,并分别显示每个子进程的进程标识号和所接收的字符串。
二. 父进程创建一子进程,父进程向子进程发送数据,子进程接收数据,并写入文件。
关键问题: 一.需要用共享内存或使用vfork()函数创建子进程进行进程之间的数据共享及传递。父进程必须等待子进程结束才能继续执行。
二.注意信号的使用。子进程需等待父进程发送信号才执行相应操作。父,子进程之间的通信需要用到共享内存或者父进程用vfork()创建子进程。
设计思路: 一.父进程使用vfork()创建两个子进程,以此实现进程之间的通信。子进程一用str1保存输入的字符串,子进程二用str2保存字符串。父进程用waitpid函数等待两个子进程分别输入完字符串,然后再分别把str1,str2显示出来。
二.用共享内存的方法来实现父子进程之间的通信,首先建立共享内存区域,然后建立子进程,并让子进程等待父进程信号。在父进程中输入字符串,并把此字符串保存在共享内存区域,然后向子进程发出信号SIGUSR1,若子进程接受到SIGUSR1信号,则把父进程保存在共享内存区域的字符串取出,并把它写入文件。
关键代码:
一.
#include
#include
#include
#include
main()
{
pid_t pid1,pid2;
char str1[20],str2[20];
if((pid1=vfork())<0)
{
perror("创建子进程一错误!\n");
exit(0);
}
else if(pid1==0)
{
printf("输入字符串一:");
scanf("%s",str1);
exit(0);
}
if((pid2=vfork())<0)
{
perror("创建子进程二错误!\n");
exit(0);
}
else if(pid2==0)
{
printf("输入字符串二:");
scanf("%s",str2);
exit(0);
}
waitpid(pid1,NULL,0);
waitpid(pid2,NULL,0);
printf("你输入的字符串一:%s\n",str1);
printf("你输入的字符串二:%s\n",str2);
}
二.
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define key 1024
#define size 160
static void sign(int);
int shmid;
char* shmaddr;
main()
{
pid_t pid;
char str[20];
shmid=shmget(key,size,IPC_CREAT|0600);
if((pid=fork())<0)
{
perror("创建子进程错误!\n");
exit(0);
}
else if(pid==0)
{
if(signal(SIGUSR1,sign)==SIG_ERR)
{
printf("SIGUSR1错误!\n");
exit(0);
}
pause();
printf("子进程结束!\n");
exit(0);
}
sleep(1);
shmaddr=(char*)shmat(shmid,NULL,0);
printf("请输入字符串:");
scanf("%s",str);
strcpy(shmaddr,str);
shmdt(shmaddr);
kill(pid,SIGUSR1);
wait();
shmctl(shmid,IPC_RMID,NULL);
}
static void sign(int signnum)
{
int fd;
char* shmaddr;
if(signnum==SIGUSR1)
{
printf("子进程接收到SIGUSR1.\n");
shmaddr=(char*)shmat(shmid,NULL,0);
if((fd=open("testfile.txt",O_RDWR|O_CREAT|O_