Java多线程学习--13

说明:参考《Java多线程核心技术》

9、ReentrantReadWriteLock
1、读读共享:读锁之间不排斥
public class ReadShareService {
    private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
    public void read() {
        try {
            try {
                lock.readLock().lock();
                System.out.println("get readLock" + Thread.currentThread().getName()
                + " " + System.currentTimeMillis());
                Thread.sleep(1000);
            }finally {
                lock.readLock().unlock();
            }
        }catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
public class ThreadA extends Thread{
    private ReadShareService service;

    public ThreadA(ReadShareService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.read();
    }
}
public class ThreadB extends Thread{
    private ReadShareService service;

    public ThreadB(ReadShareService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.read();
    }
}
public class ReadSharedTest {
    public static void main(String[] args) {
        ReadShareService service = new ReadShareService();
        ThreadA threadA = new ThreadA(service);
        threadA.setName("A");
        ThreadB threadB = new ThreadB(service);
        threadB.setName("B");

        threadA.start();
        threadB.start();
    }
}
/**
 get readLockA 1547042759434
 get readLockB 1547042759434
 */
2、写写互斥:写锁之间互斥
public class WriteMutexService {
    private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
    public void write() {
        try {
            try {
                lock.writeLock().lock();
                System.out.println("get writeLock" + Thread.currentThread().getName()
                        + " " + System.currentTimeMillis());
                Thread.sleep(1000);
            }finally {
                lock.writeLock().unlock();
            }
        }catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
public class ThreadA extends Thread{
    private WriteMutexService service;

    public ThreadA(WriteMutexService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.write();
    }
}
public class ThreadB extends Thread{
    private WriteMutexService service;

    public ThreadB(WriteMutexService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.write();
    }
}
public class WriteMutexTest {
    public static void main(String[] args) {
        WriteMutexService service = new WriteMutexService();
        ThreadA threadA = new ThreadA(service);
        threadA.setName("A");
        ThreadB threadB = new ThreadB(service);
        threadB.setName("B");

        threadA.start();
        threadB.start();
    }
}
/**
 get writeLockA 1547043671424
 get writeLockB 1547043672438
 */
3、读写互斥
public class WriteMutexService {
    private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
    public void write() {
        try {
            try {
                lock.writeLock().lock();
                System.out.println("get writeLock" + Thread.currentThread().getName()
                        + " " + System.currentTimeMillis());
                Thread.sleep(2000);
            }finally {
                lock.writeLock().unlock();
            }
        }catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

    public void read() {
        try {
            try {
                lock.readLock().lock();
                System.out.println("get readLock" + Thread.currentThread().getName()
                        + " " + System.currentTimeMillis());
                Thread.sleep(2000);
            }finally {
                lock.readLock().unlock();
            }
        }catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
public class ThreadA extends Thread{
    private WriteMutexService service;

    public ThreadA(WriteMutexService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.write();
    }
}
public class ThreadB extends Thread{
    private WriteMutexService service;

    public ThreadB(WriteMutexService service) {
        super();
        this.service = service;
    }

    @Override
    public void run() {
        service.read();
    }
}
public class WriteMutexTest {
    public static void main(String[] args) throws InterruptedException {
        WriteMutexService service = new WriteMutexService();
        ThreadA threadA = new ThreadA(service);
        threadA.setName("A");
        threadA.start();
        Thread.sleep(1000);
        ThreadB threadB = new ThreadB(service);
        threadB.setName("B");
        threadB.start();
    }
}
/**
 get writeLockA 1547044041211
 get readLockB 1547044043224
 */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值