server2.c

来自「《UNIX进程间通信》中的代码」· C语言 代码 · 共 55 行

C
55
字号
#include	"cliserv2.h"intmain(int argc, char **argv){	int		fd, index, lastnoverflow, temp;	long	offset;	struct shmstruct	*ptr;	if (argc != 2)		err_quit("usage: server2 <name>");		/* 4create shm, set its size, map it, close descriptor */	shm_unlink(Px_ipc_name(argv[1]));		/* OK if this fails */	fd = Shm_open(Px_ipc_name(argv[1]), O_RDWR | O_CREAT | O_EXCL, FILE_MODE);	ptr = Mmap(NULL, sizeof(struct shmstruct), PROT_READ | PROT_WRITE,			   MAP_SHARED, fd, 0);	Ftruncate(fd, sizeof(struct shmstruct));	Close(fd);		/* 4initialize the array of offsets */	for (index = 0; index < NMESG; index++)		ptr->msgoff[index] = index * MESGSIZE;		/* 4initialize the semaphores in shared memory */	Sem_init(&ptr->mutex, 1, 1);	Sem_init(&ptr->nempty, 1, NMESG);	Sem_init(&ptr->nstored, 1, 0);	Sem_init(&ptr->noverflowmutex, 1, 1);		/* 4this program is the consumer */	index = 0;	lastnoverflow = 0;	for ( ; ; ) {		Sem_wait(&ptr->nstored);		Sem_wait(&ptr->mutex);		offset = ptr->msgoff[index];		printf("index = %d: %s\n", index, &ptr->msgdata[offset]);		if (++index >= NMESG)			index = 0;				/* circular buffer */		Sem_post(&ptr->mutex);		Sem_post(&ptr->nempty);		Sem_wait(&ptr->noverflowmutex);		temp = ptr->noverflow;		/* don't printf while mutex held */		Sem_post(&ptr->noverflowmutex);		if (temp != lastnoverflow) {			printf("noverflow = %d\n", temp);			lastnoverflow = temp;		}	}	exit(0);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?