IO进程线程第六天作业

文章讲述了两个进程在共享内存中交替进行字符串操作,A进程打印原始字符串,B进程倒置字符串,通过信号灯集进行同步以保证顺序执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.要求在共享内存中存入字符串“1234567”"。A进程循环打印字符串,B进程循环倒置字符串,要求结果不允许出现乱序:提示:共享内存+信号灯集

 

#include <head.h>
#include <sys/shm.h>
#include <sys/sem.h>
int main(int argc, const char *argv[])
{
    //创建key
    key_t key = ftok("/home/ubuntu/",'a');
    if(key < 0)
    {
        perror("ftok");
        return -1;
    }                                            

    //创建贡献内存
    int shmid = shmget(key,128,IPC_CREAT|0664);
    if(shmid < 0)
    {
        perror("shmget");
        return -1;
    }

    //将共享内存映射到用户空间
    void *shmaddr = shmat(shmid,NULL,0);
    if(shmaddr == (void*)-1)
    {
        perror("shmat");
        return -1;
    }

    //存入一个整数
    char *ptr = (char *)shmaddr;
    strcpy(ptr,"1234567");
    system("ipcs -m");

   //通过key值获取信号灯集
   int semid = semget(key,2,IPC_CREAT|0664);
   if(semid < 0)
   {
       perror("semget");
       return -1;
   }
   //设置信号灯
   unsigned short arr[2]={0,1};
   semctl(semid,0,SETALL,arr);
   struct sembuf sops;
       while(1)
       {
           //p操作 -1
           sops.sem_num = 1;
           sops.sem_op = -1;
           sops.sem_flg = 0;
           if(semop(semid,&sops,1) < 0)
           {
               perror("semop");
               return -1;
           }
           printf("%s\n",ptr);

           sops.sem_num = 0;
           sops.sem_op = +1;
           sops.sem_flg = 0;
           if(semop(semid,&sops,1) < 0)
           {
              return -1;
          }
          //v操作 +1
      }
  
  return 0;

 }
#include <head.h>
#include <sys/shm.h>
#include <sys/sem.h>
int main(int argc, const char *argv[])
{
    //创建key
    key_t key = ftok("/home/ubuntu/",'a');
    if(key < 0)
    {
        perror("ftok");
        return -1;
    }
    //通过key值获取信号灯集
    int semid = semget(key,2,IPC_CREAT|0664);       
    if(semid < 0)
    {
        perror("semget");
        return -1;
    }

    //创建贡献内存
    int shmid = shmget(key,128,IPC_CREAT|0664);
    if(shmid < 0)
    {
        perror("shmget");
        return -1;
    }

    //将共享内存映射到用户空间
    void *shmaddr = shmat(shmid,NULL,0);
    if(shmaddr == (void*)-1)
    {
        perror("shmat");
        return -1;
    }
   char *str = (char*)shmaddr;
   char *h = NULL;  //头指针
   char *w = NULL;  //尾指针
   char temp=0;   // 中间变量

                                              
   struct sembuf sops;
   while(1)
       {
           //p操作 -1
           sops.sem_num = 0;
           sops.sem_op = -1;
           sops.sem_flg = 0;
           if(semop(semid,&sops,1) < 0)
           {
               perror("semop");
               return -1;
           }
           h = str;
           w = h + strlen(str)-1;

           //倒置字符
           while(h < w)
           {
               temp = *h;
               *h = *w;
               *w = temp;
               h++;
               w--;

           }
           sops.sem_num = 1;
           sops.sem_op = +1;
           sops.sem_flg = 0;
           if(semop(semid,&sops,1) < 0)
           {
               perror("semop");
               return -1;
           }
           //v操作 +1
       }

   return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值