线程锁 Lock
Блокировка 相当于 当前对象的 синхронизированный
импортировать java.util.concurrent.locks.lock; Import java.util.concurrent.locks.reentrantlock; / * * Lock lock = new Reentrantlock (); * lock.lock (); lock.unlock (); * 类似于 синхронизированный , 但不能与 синхронизированный 混用 */ public class locktest {public static void main (string [] args) {final over outer = new locktest (). New over (); Новый поток (new Runnable () {@Override public void run () {// todo Автогенерированный метод заглушка while (true) {outter.out1 ("zhangxioxiao"); outter.out2 ("lihuomoming");}}}). start (); Новый поток (new Runnable () {@Override public void run () {// todo Автогенерированный метод заглушка while (true) {outter.out1 ("zhangxioxiao"); outter.out2 ("lihuomoming");}}}). start (); } класс внешний {lock lock = new Reentrantlock (); void out1 (string name) {lock.lock (); int len = name.length (); for (int i = 0; i <len; i ++) {System.out.print (name.charat (i)); } System.out.println (); lock.unlock (); } void out2 (string name) {lock.lock (); int len = name.length (); for (int i = 0; i <len; i ++) {System.out.print (name.charat (i)); } System.out.println (); lock.unlock (); }}}
读写锁 Reentrantreadwritelock
读写锁 : 允许多条线程同时读;不能读中有写;不能写中有读;不能写中有写
импортировать java.util.hashmap; импортировать java.util.map; Import java.util.concurrent.locks.readwritelock; Импорт java.util.concurrent.locks.reentrantreadwritelock; / * * 问题 : 设计一个 缓存机制 伪代码 伪代码 * 从集合中读取数据 , 读取不到 , 就写入 , 再考虑多线程并发的情况 */ public class readwriteLockTest2 {private map <string, object> data = new Hashmap <String, Object> (); Частный readwritelock lock = new ReenterTreadWriteLock (); // 读写锁 Public Object getInstance1 (String Key, Object obj) {lock.readlock (). Lock (); Значение объекта = null; try {value = data.get (key); if (value == null) {// 一条线程进入这里 , lock.readlock (). unlock (); // 读锁解了 , 其他线程就可能也到这了 lock.writelock (). lock (); // 只能有一条线程到这 , 写锁开启 , 要写入数据了 if (data.get (key) == null) {value = obj; / *先判断数据 , 如果不存在 才写入 才写入 , 因为 界时当写锁解除后 , 其他 线程 , 再想写入时 判断到数据存在 判断到数据存在 就跳过了。就不会发生同时写入的情况 */ data.put (ключ, значение); } lock.writelock (). unlock (); // 写完了 , 解锁 lock.readlock (). lock (); }} наконец {lock.readlock (). unlock (); } return value; }