JAVA并发编程6

说明:先上代码,笔记后续补充。
public class LockTest2 {
private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();

public static void main(String[] args) {
final CountDownLatch latch = new CountDownLatch(2);
Long startTime = System.currentTimeMillis();
final LockTest2 test = new LockTest2();

Thread thread1 = new Thread(new Runnable() {
@Override
public void run() {
test.superGet(Thread.currentThread());
latch.countDown();
}
},"thread1");

Thread thread2 = new Thread(new Runnable() {
@Override
public void run() {
test.superGet(Thread.currentThread());
latch.countDown();
}
},"thread2");

thread1.start();
thread2.start();
try {
latch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
long endTime = System.currentTimeMillis();
long result = endTime - startTime;
System.out.println("共耗时"+result);
}

//改良之后的get
private void superGet(Thread thread){
try {
lock.readLock().lock();
//lock.writeLock().lock(); 这个≈synchronized
long start = System.currentTimeMillis();
while (System.currentTimeMillis() - start <= 1){
System.out.println(thread.getName()+"正在执行读操作");
}
System.out.println(thread.getName()+"读操作完毕");
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.readLock().unlock();
}
}

private synchronized void get(Thread thread){
long start = System.currentTimeMillis();
while (System.currentTimeMillis() - start <= 1){
System.out.println(thread.getName()+"正在执行读操作");
}
System.out.println(thread.getName()+"读操作完毕");
}
}

转载于:https://www.cnblogs.com/sleepy-goblin/p/8910065.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值