多线程的并发处理

一、线程同步方式

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>());

猜你喜欢

转载自www.cnblogs.com/pinenut/p/9073008.html