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>());
    爱码久成癖,得山真隽永
  • 相关阅读:
    Visual C#核心编程之泛型
    Visual C#核心编程之枚举器
    标准的非托管资源的销毁模式
    Visual C#核心编程之LINQ
    Visual C#核心编程之数组和集合
    ACCPSQL第四章上机六
    Visual C#2008核心编程之类型
    一月一代码 3月 kmp 领悟代码
    [转] 技巧 如何统一设置 windows live writer 的 图片大小
    understanding the linux virtual memory management 图序
  • 原文地址:https://www.cnblogs.com/pinenut/p/9073008.html
Copyright © 2011-2022 走看看