今日任务
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;
}
运行结果:
今日思维导图
明日即考,量多待复,汝甚忧之