写者优先比读者优先要复杂一些,写者优先有以下两个内涵:
1. 当写者线程获得临界区的访问权限时, 其他写者线程不要需要要优先于读者线程获得临界区的访问权限,只有当所有的写者线程都执行后,读者线程才能获得权限。
2. 当读者线程获得临界区的访问权限时,写者线程可以实现抢占,即写者线程优先于其他等待的读者线程,只有当所有的写者线程都执行后,读者线程才能获得权限。
有的参考书中对写者优先的定义仅限于上述第一条。有的定义需满足上述两条。下面分别用伪代码实现这两种情况。
int WriteCount=0, ReadCount=0// 共享变量
semaphore WriteMutex=1, ReadMutex=1, x=1,y=1;
void reader()
{
while(1)
{
sem_wait( ReadMutex);
sem_wait(x); // 保证原子操作
++ReadCount;
if(ReadCount ==1)
sem_wait(WriteMutex); //当有读者线程时应避免同时有写者线程进行写操作。