Java解决读者写者问题

596 阅读1分钟

Java解决读者写者问题

image-20200804233122508

import java.util.concurrent.Semaphore;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * Java解决读者写者问题
 *
 * @author zsw
 * @date 2020/08/04 23:35
 */
public class Demo6 {
	// 用于实现对文件的互斥访问,表示当前是否有进程在访问共享文件
	static Semaphore rw = new Semaphore(1);
	// 记录当前有几个读进程在访问文件
	static volatile AtomicInteger count = new AtomicInteger(0);
	static Semaphore mutex = new Semaphore(1);
	// 用于实现写优先
	static Semaphore w = new Semaphore(1);

	public static void main(String[] args) {
		for (int i = 0; i < 3; i++) {
			Thread writer = new Thread(new Write());
			writer.setName("writer" + i);
			writer.start();

			Thread read = new Thread(new Read());
			read.setName("read" + i);
			read.start();
		}
	}

	static class Write implements Runnable {
		static int num = 0;

		@Override
		public void run() {
			while (true) {
				try {
					w.acquire();
					rw.acquire();
					System.out.println(Thread.currentThread().getName() + "写完了");
				} catch (InterruptedException e) {
					e.printStackTrace();
				} finally {
					rw.release();
					w.release();
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
			}
		}
	}

	static class Read implements Runnable {

		@Override
		public void run() {
			try {
				w.acquire();
				mutex.acquire();
				if (count.get() == 0) {
					// 第一个读进程进行加锁
					rw.acquire();
				}
				count.incrementAndGet();
				mutex.release();
				w.release();
				System.out.println(Thread.currentThread().getName() + "读完了");
				mutex.acquire();
				count.decrementAndGet();
				// 没有进程访问了,则释放临界资源
				if (count.get() == 0) {
					rw.release();
				}
				mutex.release();
				Thread.sleep(10);
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}

}