本文为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 */
时间: 2024-10-14 09:33:17