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

本文为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)
{
	int		fd;
	pthread_mutexattr_t	mattr;


	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 */


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值