zoukankan      html  css  js  c++  java
  • 多线程的并发处理

    一、线程同步方式

    1.关键字(synchronized)

      Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码

          a) 当两个并发线程访问同一个对象object中的这个synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行,另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。

           b) 当一个线程访问object的一个synchronized(this)同步代码块时,其他线程对object中所有其它synchronized(this)同步代码块的访问将被阻塞

    1     public synchronized void foo( B b )
    2     {
    3         System.out.println("当前线程名: " + Thread.currentThread().getName()
    4             + " 进入了A实例的foo()方法" );     //
    5     }

    2.同步锁(lock)

      Lock是控制多个线程对共享资源进行访问的工具.通常,锁提供了对共享资源的独占访问,每次只能有一个,线程对Lock对象加锁,线程开始访问共享资源之前,应该先获得Lock对象。

     1     //定义锁对象
     2     private final ReentrantLock lock = new ReentrantLock();
     3     //定义需要保证线程安全的方法
     4     public void m(){
     5         lock.lock();
     6         try{
     7             //需要保证线程安全的代码
     8             //...method body
     9         }
    10         //使用finally块来保证释放锁
    11         finally{
    12             lock.unlock();
    13         }
    14     }

    二、线程安全集合

    目前,java支持的线程安全集合类有两类

    a)以Concurrent开头的集合类,包括ConcurrentHashMap、ConcurrentSkipListMap、ConcurrentSkipListSet、ConcurrentLinkedQueue、ConcurrentLinkedDeque。

    b)以CopyOnWrite开头的集合类,包括CopyOnWriteArrayList、CopyOnWriteArraySet。

    另外,ArrayList,LinkedList,HashSet,TreeSet,HashMap,TreeMap等都是线程不安全的.

    如果程序中有多个线程可能访问以上这些集合,就可以使用Collection提供的类方法把这些结婚包装成线程安全的集合。

    HashMap<String,String> m = (HashMap<String, String>) Collections.synchronizedMap(new HashMap<String, String>());
    爱码久成癖,得山真隽永
  • 相关阅读:
    KM匹配模板
    BestCoder 1st Anniversary 1002-1005
    SGU 106 The equation
    sgu 104 Little shop of flowers
    SGU Magic Pairs
    关于 “'sqlite3' 不是内部或外部命令.....”问题
    通过django 速成 blog
    windows 通过appache链接cgi程序
    A Lot of Games(Trie树 + 博弈)
    树的点分治 (poj 1741, 1655(树形dp))
  • 原文地址:https://www.cnblogs.com/pinenut/p/9073008.html
Copyright © 2011-2022 走看看