UNIX网络编程卷1 服务器程序设计范式4 预先派生子进程,以线程互斥锁上锁方式保护accept

时间:2022-01-07 07:28:59

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie


1.文件上锁文件系统操作,比较耗时
2.线程上锁,不仅适用于同一进程内各线程之间的上锁,也适用于不同进程之间的上锁。
3.在不同进程之间使用线程上锁要求:
1)互斥锁变量必须存放在由所有进程共享的内存区中
2)必须告知线程函数库这是在不同进程之间共享的互斥锁


/* include my_lock_init */
#include"unpthread.h"
#include<sys/mman.h>


static pthread_mutex_t*mptr;/* actual mutex will be in shared memory */


void
my_lock_init(char *pathname)
{
intfd;
pthread_mutexattr_tmattr;


fd = Open("/dev/zero", O_RDWR, 0);


//1.使用 mmap 函数将 /dev/zero 映射到内存中
mptr = Mmap(0, sizeof(pthread_mutex_t), PROT_READ | PROT_WRITE,
MAP_SHARED, fd, 0);


//关闭描述符,因为该描述符已被内存映射了
Close(fd);


//2.调用一些 Pthread 库函数以告诉该函数库:这是一个位于共享内存区中的互斥锁,
//将用于不同进程之间的上锁
Pthread_mutexattr_init(&mattr); //首先为一个互斥锁以默认属性初始化一个 pthread_mutexattr_t 结构
Pthread_mutexattr_setpshared(&mattr, PTHREAD_PROCESS_SHARED); //然后赋予该结构 PTHREAD_PROCESS_SHARED 的属性,使它可以在多个进程内使用
Pthread_mutex_init(mptr, &mattr); // 最后调用 pthread_mutex_init 函数以这些属性初始化共享内存区中的互斥锁
}
/* end my_lock_init */


/* include my_lock_wait */
void
my_lock_wait()
{
Pthread_mutex_lock(mptr);
}


void
my_lock_release()
{
Pthread_mutex_unlock(mptr);
}
/* end my_lock_wait */