IO周二作业

文章描述了两个进程如何在共享内存中协作,一个进程循环打印字符串,另一个进程循环倒置字符串,使用信号量进行同步,确保结果不乱序。
摘要由CSDN通过智能技术生成
在共享内存中存入字符串“1234567”。A进程循环打印字符串,B进程循环倒置字符串,要求结果不允许出现乱序。
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/sem.h>
int main(int argc, const char *argv[])
{
	key_t key = ftok("./",10);
	if(key < 0 )
	{
		perror("ftok");
		return -1;
	}
	printf("%#x \n",key);
	int shmid = shmget(key,128,IPC_CREAT|0664);
	if(shmid<0)
	{
		perror("shmget");
		return -1;
	}
	printf("shmid = %d\n",shmid);
	void* shmaddr = shmat(shmid,NULL,0);
	if((void*)-1 == shmaddr)
	{
		perror("shmaddr");
		return -1;
	}
	printf("shmaddr = %p \n",shmaddr);
	char *str = (char*)shmaddr;
	char *start =str;
	char *end = str+strlen(str)-1;
	char temp = 0;
	struct sembuf sop;


	while(1)
	{
		temp = *start;
		*start = temp;
		*end = temp;

		start++;
		temp--;
	}
	sop.sem_num = 1;
	sop.sem_op = +1;
	sop.sem_flg = 0;
	if(semop(shmid,&sop,1)<0)
	{
		perror("semop");
		return -1;
	}
		
	return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <string.h>
#include <unistd.h>
#include <sys/sem.h>
#include <sys/shm.h>
int main(int argc, const char *argv[])
{
	key_t key = ftok("./",10);
	if(key<0)
	{
		perror("ftok");
		return -1;
	}
	printf("%#x\n",key);
	//创建信号灯集
	int semid = semget(key,2,IPC_CREAT|0664);
	if(semid < 0)
	{
		perror("semget");
		return -1;
	}
	//设置信号灯的值
	unsigned short arr[2]={0,1};
	if(semctl(semid,0,SETALL,arr)<0)
	{
		perror("semctl");
		return -1;
	}
	//创建共享内存
	int shmid = shmget(key,128,IPC_CREAT|0664);
	if(shmget<0)
	{
		perror("shmge");
		return -1;
	}
	printf("shmid = %d \n",shmid);

	//映射到用户空间
	void *shmaddr = shmat(shmid,NULL,0);
	if((void*)-1 == shmaddr)
	{
		perror("shmaddr");
		return -1;
	}
	printf("shmaddr = %p\n",shmaddr);
	char * str = (char*)shmaddr;
	strcpy(str,"123456");
	struct sembuf sop;
	while(1)
	{
		sop.sem_num = 1;  //控制1号灯
		sop.sem_op = -1;  //p操作
		sop.sem_flg = 0;  //阻塞方式
		if(semop(semid,&sop,1)<0)
		{
			perror("semop");
			return -1;
		}
		printf("%s\n",str);
		sop.sem_num = 0;  //控制0号灯
		sop.sem_op = +1;  //V操作
		sop.sem_flg = 0;  //阻塞方式
		if(semop(semid,&sop,1)<0)
		{
			perror("semop");
			return -1;
		}
	}
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值