IO进程线程->进程间的通信->day8

目录

一、A、B线程间的通信

1.1 A进程函数

1.2 B进程函数

1.3 执行结果

二、内存共享

2.1  A进程代码

 2.2  B进程代码

2.3 执行结果


一、A、B线程间的通信

1)要求AB进程做通信

A进程随时发送一句话,B进程接收打印

B进程随时发送给A进程一句话,A进程接收打印

重复1,2步骤,直到A进程或者B进程收到quit,退出AB进程

        使用消息队列

1.1 A进程函数

#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>

struct msgnode
{
	long mtype;
	int msgqid;
	char mtext[128];
};


void* A_r(void* arg)
{
	
	struct msgnode *q = (struct msgnode*)arg;
	ssize_t res=0;
	while(1)
	{
	//	bzero(q->mtext,sizeof(q->mtext));
		res=msgrcv(q->msgqid,q,sizeof(q->mtext),2,0);
		if(res<0)
		{
			perror("msgrcv");
			return NULL;
		}
		if(strcasecmp(q->mtext,"quit") == 1)
		{
			exit(0);
		}
		printf("B进程说:[%ld]%s\n",q->mtype,q->mtext);

	}
	pthread_exit(NULL);
}

void* A_w(void* arg)
{
	struct msgnode *q = (struct msgnode*)arg;
	ssize_t res=0;
	while(1)
	{
	//	bzero(q->mtext,sizeof(q->mtext));
		printf("A进程输入>>");
		fgets(q->mtext,sizeof(q->mtext),stdin);
		q->mtext[strlen(q->mtext)-1]='\0';
		q->mtype=1;
		if(msgsnd(q->msgqid,q,sizeof(q->mtext),0)<0)
		{
			perror("msgsnd");
			return NULL;
		}
		if(strcasecmp(q->mtext,"quit") == 0)
		{
			exit(0);
		}
		printf("A进程写入成功\n");
	}
	pthread_exit(NULL);
}



int main(int argc, const char *argv[])
{
	struct msgnode snd;
	key_t key=ftok("./",1);
	if(key<0)
	{
		perror("ftok");
		return -1;
	}
	printf("key= %#x\n",key);

	//创建消息队列
	snd.msgqid=msgget(key,IPC_CREAT|0664);
	if(snd.msgqid<0)
	{
		perror("msgget");
		return -1;
	}
	printf("msqid= %d\n",snd.msgqid);
	//创建线程
	pthread_t tid1,tid2;
	if(pthread_create(&tid1,NULL,A_r,(void *)&snd) != 0)
	{
		perror("pthread_create");
		return-1;
	}
	if(pthread_create(&tid2,NULL,A_w,(void *)&snd) != 0)
	{
		perror("pthread_create");
		return-1;
	}
	printf("线程创建成功\n");



	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);

	return 0;
}

1.2 B进程函数

#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>

struct msgnode
{
	long mtype;
	int msgqid;
	char mtext[128];
};


void* B_w(void* arg)
{
	struct msgnode *q = (struct msgnode*)arg;
	ssize_t res=0;
	while(1)
	{
//		bzero(q->mtext,sizeof(q->mtext));
		printf("B进程输入>>");
		fgets(q->mtext,sizeof(q->mtext),stdin);
		q->mtext[strlen(q->mtext)-1]='\0';
		q->mtype=2;
		if(msgsnd(q->msgqid,q,sizeof(q->mtext),0)<0)
		{
			perror("msgsnd");
			return NULL;
		}
		if(strcasecmp(q->mtext,"quit") == 1)
		{
			exit(0);
		}
		printf("b进程写入成功\n");
	}
	pthread_exit(NULL);
}

void* B_r(void* arg)
{	
	struct msgnode *q = (struct msgnode*)arg;
	ssize_t res=0;
	while(1)
	{
	//	bzero(q->mtext,sizeof(q->mtext));
		res=msgrcv(q->msgqid,q,sizeof(q->mtext),1,0);
		if(res<0)
		{
			perror("msgrcv");
			return NULL;
		}
		if(strcasecmp(q->mtext,"quit") == 0)
		{
			exit(0);
		}
		printf("A进程说:[%ld]%s\n",q->mtype,q->mtext);

	}
	pthread_exit(NULL);

}

int main(int argc, const char *argv[])
{
	struct msgnode snd;
	key_t key=ftok("./",1);
	if(key<0)
	{
		perror("ftok");
		return -1;
	}
	printf("key= %#x\n",key);

	//创建消息队列
	snd.msgqid=msgget(key,IPC_CREAT|0664);
	if(snd.msgqid<0)
	{
		perror("msgget");
		return -1;
	}
	printf("msqqid= %d\n",snd.msgqid);
	//创建线程
	pthread_t tid1,tid2;
	if(pthread_create(&tid1,NULL,B_r,(void *)&snd) != 0)
	{
		perror("pthread_create");
		return-1;
	}
	if(pthread_create(&tid2,NULL,B_w,(void *)&snd) != 0)
	{
		perror("pthread_create");
		return-1;
	}
	printf("线程创建成功\n");



	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);

	return 0;
}

1.3 执行结果


二、内存共享

  1. A进程写入一个整型,在该整型后,写入一个字符串

  2. B进程将共享内存中的整型以及字符串读取出来;

2.1  A进程代码

#include <stdio.h>
#include <sys/ipc.h> 
#include <sys/shm.h>
#include <sys/types.h>
#include <string.h>

int main(int argc, const char *argv[])
{
	key_t key=ftok("./",1);
	if(key<0)
	{
		perror("shmget");
		return -1;
	}
	int shm=shmget(key,128,IPC_CREAT|0664);
	if(shm<0)
	{
		perror("shmget");
		return -1;
	}
	void* q=shmat(shm,NULL,0);
	if(q == (void*)-1)
	{
		perror("shmat");
		return -1;
	}
	int* p=(int *)q;
	int a=0;
	printf("请输入一个整形\n");
	scanf(" %d",&a);
	*p=a;
	p++;

	char arr[128]="";
	printf("请输入一个字符\n");
	scanf(" %s",arr);
	strcpy((char*)p,arr);

	printf("写入成功\n");

	
	return 0;
}

 2.2  B进程代码

#include <stdio.h>
#include <sys/ipc.h> 
#include <sys/shm.h>
#include <sys/types.h> 
#include <string.h>  

int main(int argc, const char *argv[])
{
	key_t key=ftok("./",1);
	if(key<0)
	{
		perror("shmget");
		return -1;
	}
	int shm=shmget(key,128,IPC_CREAT|0664);
	if(shm<0)
	{
		perror("shmget");
		return -1;
	}
	void* q=shmat(shm,NULL,0);
	if(q == (void*)-1)
	{
		perror("shmat");
		return -1;
	}
	int* p=(int *)q;
	printf("输出一个整形:%d\n",*p);
	p++;
	printf("输出一个字符串:%s\n",(char*)p);

	printf("输出成功\n");

	
	return 0;
}


2.3 执行结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值