IO和进程day08(消息队列、共享内存、信号灯集)

今日任务

1.代码 

inversion.c

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

int main(int argc, const char *argv[])
{
	//创建打开共享内存
	
	//1.生成key
	key_t key=ftok("./",1);
	if(-1==key){
		perror("key");
		return -1;
	}
	//2.获取id号
	int shmId=shmget(key,128,IPC_CREAT|0664);
	if(-1==shmId){
		perror("shmget");
		return -1;
	}
	//3.获取映射地址
	void* addr=shmat(shmId,NULL,0);
	if((void *)-1==addr){
		perror("shmat");
		return -1;
	}
	char *q=(char*)addr;
	//创建信号量集,共创建两灯:
	//0:初始值为1,负责打印,打印前0号灯-1;打印结束,1号灯+1;
	//1:初始值为0,负责逆置,逆置前1号灯-1;逆置结束,0号灯+1;
	int semId=semget(key,2,IPC_CREAT|0664);
	if(-1==semId){
		perror("semId");
		return -1;
	}
	struct sembuf sops={0,1,0};
	if(-1==semop(semId,&sops,1)){
		perror("semop");
		return -1;
	}
	puts("初始化完成");
	struct sembuf p={1,-1,0};//1号灯-1
	struct sembuf v={0,1,0};//0号灯+1
	while(1){
		//逆置
		if(-1==semop(semId,&p,1)){
			perror("semop p");
			return -1;
		}
		//操作
		for (int i=0; i<strlen(q)/2; i++)
		{
			char temp=*(q+i);
			*(q+i)=*(q+strlen(q)-1-i);
			*(q+strlen(q)-1-i)=temp;
		}
		if(-1==semop(semId,&v,1)){
			perror("semop p");
			return -1;
		}
	}
	return 0;
}

print.c

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

int main(int argc, const char *argv[])
{
	//创建打开共享内存
	
	//1.生成key
	key_t key=ftok("./",1);
	if(-1==key){
		perror("key");
		return -1;
	}
	//2.获取id号
	int shmId=shmget(key,128,IPC_CREAT|0664);
	if(-1==shmId){
		perror("shmget");
		return -1;
	}
	//3.获取映射地址
	void* addr=shmat(shmId,NULL,0);
	if((void *)-1==addr){
		perror("shmat");
		return -1;
	}
	strcpy((char*)addr,"1234567");
	//创建信号量集,共创建两灯:
	//0:初始值为1,负责打印,打印前0号灯-1;打印结束,1号灯+1;
	//1:初始值为0,负责逆置,逆置前1号灯-1;逆置结束,0号灯+1;
	int semId=semget(key,2,IPC_CREAT|0664);
	if(-1==semId){
		perror("semId");
		return -1;
	}
	struct sembuf sops={0,1,0};
	if(-1==semop(semId,&sops,1)){
		perror("semop");
		return -1;
	}
	puts("初始化完成");
	struct sembuf p={0,-1,0};//0号灯-1
	struct sembuf v={1,1,0};//1号灯+1
	while(1){
		//打印,
		if(-1==semop(semId,&p,1)){
			perror("semop p");
			return -1;
		}
		//操作
		sleep(1);
		printf("%s\n",(char*)addr);
		if(-1==semop(semId,&v,1)){
			perror("semop p");
			return -1;
		}
	}
	return 0;
}

运行结果:

今日思维导图

明日即考,量多待复,汝甚忧之

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值