多线程学习笔记(二)

本文深入探讨了Java并发编程的关键概念和技术,包括synchronized关键字、锁与条件变量、死锁避免、公平锁策略、读写锁机制及阻塞队列的使用等。通过详细解释这些核心概念,帮助读者理解如何有效管理和控制多线程环境下的资源访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.5,5

synchronized关键字  

lock和condition的关键点:       

 1.锁用来保护代码片断,任何时刻只允许一个线程执行被保护的代码。    

  2.锁可以管理试图进入被保护代码短的线程。       

3.锁可以拥有一个或多个相关的条件对象。        

4.每个条件对象管理那些已进入被保护代码段但还不能运行的线程。   

Condtion的await()和signalAll()方法等价于thread的wait()和notifyAll()方法

1.5.8 死锁
        当程序挂起后,就是所有线程都挂起后,按CTRL+/,将会得到所有线程的列表。每一个线程都有一

个堆栈踪迹,它会告诉你当前在哪里阻塞了。

1.5.9 公平
          Lock lock = new ReentrantLock(true);//设置为公平锁策略。

         公平锁策略会优待那些等待了最长时间的线程。但是,这会大大影响性能。所以默认下是非公平的。

1.5.10  锁测试和超时

java.util.concurrent.locks.Lock 5.0

boolean tryLock()

如果锁可用,则获取锁,并立即返回值 true。如果锁不可用,则此方法将立即返回值 false

boolean tryLock(long time,TimeUnit unit)

尝试获得锁,但阻塞时间不会超过给定的值;如果成功返回true;

void lockInterruptibly()

获得锁,但是会不确定地发生阻塞。如果线程被中断,抛出一个InterruptedException异常。

1.5.11  读/写锁

    1)创建一个ReentrantReadWriteLock 对象

     private  ReentrantReadWriteLock  rwl  =  new  ReentrantReadWriteLock ();

   2)抽取读锁和写锁

     private  Lock  readlock = rwl.readLock();

     private  Lock  writeock = rwl.writeLock();

   3)对所有访问者加读锁

    public  double  getTotalBalance()

   {

   readlock.lock();

   ...................

   }

   1.6  阻塞队列

   ConcurrentHashMap具有一些很有用地方法来进行原子行地关联插入和关联移出操作。

 putIfAbsent(key,value);

如果指定键已经不再与某个值相关联,则将它与给定值关联。这等价于:

   if (!map.containsKey(key)) 
      return map.put(key, value);
  else
       return map.get(key);

replace(key,oldValue,newValue);

只有目前将键的条目映射到给定值时,才替换该键的条目。这等效于:

   if (map.containsKey(key) && map.get(key).equals(oldValue)) {
       map.put(key, newValue);
       return true;
   } else return false;

1.7.3 旧的线程安全地集合

  JDK1.2中,Vector和hashtable被弃用了,虽然他们是线程安全地动态数组!

   替代它们的是ArrayList和hashMap,虽然这些不是线程安全的,但可以利用一下操作实现线程安全:

  List synchList = Collections.synchronizedList(new ArrayList());

  Map synchMap= Collections.synchronizedList(new HashMap());

但是如果你想迭代这个Collection的化,必须使用一个同步块:

synchronized  (synchMap)

{

   Iterator iter = synchMap.keySet().iterator();

}

1.9  执行器

  1.9.1线程池




               

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值