dayIO8作业

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <dirent.h>
#include <sys/wait.h>
#include <pthread.h>
#include <semaphore.h>
#include <sys/ipc.h>
#include <sys/msg.h>
typedef struct msg
{
	long type;
	char text[256];
}msg_t;
void* task1(void *arg)
{

	key_t key=ftok("./ipc",1);
	if(key==-1)
	{
		perror("fork");
		return NULL;
	}
	int id=msgget(key,IPC_CREAT|0666);//消息队列id

	msg_t buf;
	int len=0;
	while(1)
	{
		memset(&buf,0,sizeof(msg_t));
		buf.type=1;
		printf("请输入消息:\n");
		scanf("%256s",buf.text);
		while(getchar()!=10);
		len=strlen(buf.text);
		msgsnd(id,&buf,len,0);                         
	}
	msgctl(id,IPC_RMID,NULL);

}
void* task2(void *arg)
{
	key_t key=ftok("./ipc",1);
	if(key==-1)
	{
		perror("fork");
		return NULL;
	}
	int id=msgget(key,IPC_CREAT|0666);//消息队列id
	msg_t buf;
	int len=0;
	while(1)
	{  
		memset(&buf,0,sizeof(msg_t));    
		len=msgrcv(id,&buf,256,2,0);
		printf("读到的消息:%s\n",buf.text);
		if(strcmp("quit_pid",buf.text)==0)
		break;
		printf("请输入消息:\n");
		fflush(stdout);
	}
	msgctl(id,IPC_RMID,NULL);
}
int main(int argc, const char *argv[])
{
	pthread_t id1;
	pthread_create(&id1,0,task1,NULL);
	pthread_t id2;
	pthread_create(&id2,0,task2,NULL);
	pthread_join(id1,NULL);
	pthread_join(id2,NULL);
	return 0;
}
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <dirent.h>
#include <sys/wait.h>
#include <pthread.h>
#include <semaphore.h>
#include <sys/ipc.h>
#include <sys/msg.h>
typedef struct msg
{
	long type;
	char text[256];
}msg_t;
void* task1(void *arg)
{
	key_t key=ftok("./ipc",1);
	if(key==-1)
	{
		perror("fork");
		return NULL;
	}
	int id=msgget(key,IPC_CREAT|0666);//消息队列id
	msg_t buf;
	int len=0;
	while(1)
	{  
		memset(&buf,0,sizeof(msg_t));    
		len=msgrcv(id,&buf,256,1,0);
		printf("读到的消息:%s\n",buf.text);
		if(strcmp("quit_pid",buf.text)==0)
		break;
		printf("请输入消息:\n");
	}
	msgctl(id,IPC_RMID,NULL);


}
void* task2(void *arg)
{

	key_t key=ftok("./ipc",1);
	if(key==-1)
	{
		perror("fork");
		return NULL;
	}
	int id=msgget(key,IPC_CREAT|0666);//消息队列id

	msg_t buf;
	int len=0;
	while(1)
	{
		memset(&buf,0,sizeof(msg_t));
		buf.type=2;
		printf("请输入消息:\n");
		scanf("%256s",buf.text);
		while(getchar()!=10);
		len=strlen(buf.text);
		msgsnd(id,&buf,len,0);                         
	}
	msgctl(id,IPC_RMID,NULL);

}
int main(int argc, const char *argv[])
{
	pthread_t id1;
	pthread_create(&id1,0,task1,NULL);
	pthread_t id2;
	pthread_create(&id2,0,task2,NULL);
	pthread_join(id1,NULL);
	pthread_join(id2,NULL);
	return 0;
}

 

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <dirent.h>
#include <sys/wait.h>
#include <pthread.h>
#include <semaphore.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <sys/shm.h>
#include <sys/sem.h>
typedef struct
{
	char text[256];
}shm_t;
void semwait(int id,int index)//信号灯集合id与下标 获取信号量-1
{
	struct sembuf buf={0};
	buf.sem_num=index;//需要操作的集合下标
	buf.sem_op=-1;//信号量减一
	buf.sem_flg=SEM_UNDO;
	semop(id,&buf,1);
}
void sempost(int id,int index)//信号灯集合id与下标 获取信号量-1
{
	struct sembuf buf={0};
	buf.sem_num=index;//需要操作的集合下标
	buf.sem_op=1;//信号量加一
	buf.sem_flg=SEM_UNDO;
	semop(id,&buf,1);
}
int main(int argc, const char *argv[])
{	

	key_t key=ftok("./aaaa",1);
	if(key==-1)
	{
		perror("ftok");
		return -1;
	}
	int shm_id=shmget(key,sizeof(shm_t),IPC_CREAT|0666);//共享内存大小256
	if(shm_id==-1)
	{
		perror("shmget");
		return -1;
	}
	//共享内存映射
	shm_t* addr=shmat(shm_id,NULL,0);//NULL自动选择内存,0共享内存可读可写

	//key_t key2=ftok("./ipc1",2);
	int sem_id=semget(key,4,IPC_CREAT|0666);//创建信号灯集的信号量
	if(sem_id==-1)
	{
		perror("semget");
		return -1;
	}



	//初始化信号灯集的每一个信号量
	semctl(sem_id,0,SETVAL,1);
	semctl(sem_id,1,SETVAL,0);
	semctl(sem_id,2,SETVAL,1);
	semctl(sem_id,3,SETVAL,0);

	int res=fork();
	int len=0;
	if(res>0)
	{
		while(1)
		{
			semwait(sem_id,0);//获取0号下标信号量
			memset(&addr,0,256);
			printf("请输入数据:");
			//fgets(addr->text,256,stdin);
			scanf("%s",addr->text);
			while(getchar()!=10);
			addr->text[strlen(addr->text)-1]='\0';
			printf("%s",addr->text);
			sempost(sem_id,1);
		}
		wait(0);
	}
	else if(res==0)
		while(1)
		{
			semwait(sem_id,2);//获取0号下标信号量
			printf("收到的消息:%s\n",addr->text);
			memset(&addr,0,256);
			sempost(sem_id,3);
		}


return 0;
}
ubun

 

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <dirent.h>
#include <sys/wait.h>
#include <pthread.h>
#include <semaphore.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <sys/shm.h>
#include <sys/sem.h>
typedef struct shmw
{
	char text[256];
}shm_t;
void semwait(int id,int index)//信号灯集合id与下标 获取信号量-1
{
	struct sembuf buf={0};
	buf.sem_num=index;//需要操作的集合下标
	buf.sem_op=-1;//信号量减一
	buf.sem_flg=SEM_UNDO;
	semop(id,&buf,1);
}
void sempost(int id,int index)//信号灯集合id与下标 获取信号量-1
{
	struct sembuf buf={0};
	buf.sem_num=index;//需要操作的集合下标
	buf.sem_op=1;//信号量加一
	buf.sem_flg=SEM_UNDO;
	semop(id,&buf,1);
}
int main(int argc, const char *argv[])
{	
	key_t key=ftok("./aaaa",1);
	if(key==-1)
	{
		perror("ftok");
		return -1;
	}
	int shm_id=shmget(key,256,IPC_CREAT|0664);//共享内存大小256
	if(shm_id==-1)
	{
		perror("shmget");
		return -1;
	}
	shm_t* addr=shmat(shm_id,NULL,0);//NULL自动选择内存,0共享内存可读可写
//	key_t key2=ftok("./ipc1",2);
	int sem_id=semget(key,4,IPC_CREAT|0666);//创建信号灯集的信号量
	if(sem_id==-1)
	{
		perror("semget");
		return -1;
	}
	//共享内存映射


	//初始化信号灯集的每一个信号量
	/*
	semctl(sem_id,0,SETVAL,1);
	semctl(sem_id,1,SETVAL,0);
	semctl(sem_id,2,SETVAL,0);
	semctl(sem_id,3,SETVAL,0);
*/
	int res=fork();
	int len=0;
	if(res>0)
	{

		while(1)
		{
			semwait(sem_id,1);//获取0号下标信号量
			printf("收到的消息:%s\n",addr->text);
			memset(&addr,0,256);
			sempost(sem_id,0);
		}
		wait(0);
	}
	else if(res==0)
		while(1)
		{
			semwait(sem_id,3);//获取0号下标信号量
			memset(&addr,0,256);
			printf("请输入数据:");
			scanf("%s",addr->text);
			while(getchar()!=10);
			sempost(sem_id,2);
		}


return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值