gpt4 book ai didi

c - 一种用互斥量同步读取和修改的方法

转载 作者:太空宇宙 更新时间:2023-11-04 04:16:59 25 4
gpt4 key购买 nike

我正在实现 Web 代理服务器缓存的同步。有两种情况:

  1. 如果缓存正在被修改,则不能被其他人修改线程
  2. 如果缓存正在被读取,则不能被其他人修改线程,但它可以被其他线程读取。

我想让缓存可读,即使它正在被其他线程读取。

int readflag = 0;
// read
void read()
{
pthread_mutex_lock();
pthread_mutex_unlock();
++readflag;
/* read the cache*/
--readflag;
}

// modify
void write()
{
while(readflag > 0);
pthread_mutex_lock();
/* modify the cache*/
pthread_mutex_unlock();
}

这是我的简单代码。但是,它看起来很尴尬,而且也不是线程安全的。我怎样才能实现这种同步?

最佳答案

Pthreads 为此提供了读写锁。

带有 pthreads 读写锁的示例:

#include <pthread.h>
#include <assert.h>

static pthread_rwlock_t rwlock = PTHREAD_RWLOCK_INITIALIZER;

static void read()
{
int r;
r=pthread_rwlock_rdlock(&rwlock);
assert(0==r);
//lock/unlock ops can't fail
//unless your program's logic is flawed

/* read the cache*/
r=pthread_rwlock_unlock(&rwlock); assert(0==r);
}

// modify
static void write()
{
int r;
r=pthread_rwlock_wrlock(&rwlock); assert(0==r);
/* modify the cache*/
r=pthread_rwlock_unlock(&rwlock); assert(0==r);
}

关于c - 一种用互斥量同步读取和修改的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50695297/

25 4 0