- 浏览: 395477 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (760)
- 股票日志 (26)
- Selenium (0)
- selenium 2 环境的搭建 (1)
- 并发 (7)
- 框架开发 (1)
- 动态代理 (2)
- Struts2 (2)
- POI (2)
- jdk (3)
- maven (31)
- spring (35)
- mysql (31)
- 工作机会 (3)
- xtream (1)
- oracle dbms_metadata GET_DDL (0)
- SSI (1)
- DB (61)
- powermock (4)
- java 基础 (25)
- 多线程 (11)
- 高手 (2)
- java 底层 (2)
- 专业网站 (1)
- 开发联想 (1)
- 开发联想 (1)
- bat文件 (2)
- 清queue 语句 (1)
- 清queue 语句 (1)
- jquery (7)
- html5 (1)
- Jenkins (10)
- Linux (17)
- 工作issue (2)
- tomcat log (3)
- jvm (23)
- 项目细节 (0)
- oracle (41)
- 泛型 (3)
- 新知识点 (1)
- 数据库ddl 语句 (0)
- AQ (2)
- jms (0)
- 网络资源 (6)
- github (6)
- Easymock (1)
- Dom 解析XML (1)
- windows命令 (2)
- java (7)
- 正则表达式 (5)
- sequence (1)
- oracle 表meta信息 (1)
- 小工具技巧 (1)
- 辅助工具 (1)
- Junit (1)
- 泛型 generic (2)
- Java程序设计 (1)
- cglib (2)
- 架构师之路 (1)
- 数据库连接池 (5)
- c3p0 (1)
- eclipse使用 (1)
- oracle sql plus (1)
- 码农人生 (3)
- SVN (15)
- sqlplus (2)
- jsoup (1)
- 网络爬虫 (2)
- 新技能 (1)
- zookeeper (4)
- hadoop (1)
- SVNKIT (1)
- 从工具到知识点的整理 (1)
- log4j (13)
- 读文件 (0)
- 转义字符 (1)
- command (1)
- web service (3)
- 锁 (1)
- shell 脚本 (1)
- 遇到的错误 (2)
- tomcat (14)
- 房产 (5)
- bootstrap jquery ui (1)
- easyui (2)
- 个人征信 (1)
- 读写分离 (1)
- 备份 (1)
- rmi (6)
- webservice (1)
- JMX (4)
- 内存管理 (3)
- java设计 (1)
- timer (1)
- lock (2)
- concurrent (2)
- collection (1)
- tns (1)
- java基础 (15)
- File (1)
- 本机资源 (1)
- bat (1)
- windows (4)
- 数据结构 (3)
- 代码安全 (1)
- 作用域 (1)
- 图 (2)
- jvm内存结构 (1)
- 计算机思想 (1)
- quartz (6)
- Mongo DB (2)
- Nosql (4)
- sql (5)
- 第三方Java 工具 jar 项目 (2)
- drools (1)
- java swing (2)
- 调用console (1)
- runtime (1)
- process (1)
- swing (2)
- grouplayout (1)
- dubbo (0)
- bootstrap (0)
- nodejs (2)
- SVN hooks (1)
- jdbc (3)
- jdbc error (1)
- precedure (1)
- partition_key (1)
- active mq (1)
- blob (2)
- Eclipse (6)
- web server (1)
- bootstrapt (2)
- struts (1)
- ajax (1)
- js call back (1)
- 思想境界拓展 (1)
- JIRA (1)
- log (1)
- jaxb (3)
- xml java互相转换 (1)
- 装修 (2)
- 互联网 (2)
- threadlocal (3)
- mybatis (22)
- xstream (1)
- 排序 (1)
- 股票资源 (1)
- RPC (2)
- NIO (3)
- http client (6)
- 他人博客 (1)
- 代理服务器 (1)
- 网络 (2)
- web (1)
- 股票 (5)
- deadlock (1)
- JConsole (2)
- activemq (3)
- oralce (1)
- 游标 (1)
- 12月13日道富内部培训 (0)
- grant (1)
- 速查 (2)
- classloader (4)
- netty (4)
- 设计模式 (2)
- 缓存 (2)
- ehcache (2)
- framework (1)
- 内存分析 (2)
- dump (1)
- memory (2)
- 多高线程,并发 (1)
- hbase (2)
- 分布式系统 (1)
- socket (3)
- socket (1)
- 面试问题 (1)
- jetty (2)
- http (2)
- 源码 (1)
- 日志 (2)
- jni (1)
- 编码约定 (1)
- memorycache (1)
- redis (13)
- 杂谈 (1)
- drool (1)
- blockingqueue (1)
- ScheduledExecutorService (1)
- 网页爬虫 (1)
- httpclient (4)
- httpparser (1)
- map (1)
- 单例 (1)
- synchronized (2)
- thread (1)
- job (1)
- hashcode (1)
- copyonwriteArrayList (2)
- 录制声音 (1)
- java 标准 (2)
- SSL/TLS (1)
- itext (1)
- pdf (1)
- 钻石 (2)
- sonar (1)
- unicode (1)
- 编码 (4)
- html (1)
- SecurityManager (1)
- 坑 (1)
- Restful (2)
- svn hook (1)
- concurrentHashMap (1)
- 垃圾回收 (1)
- vbs (8)
- visual svn (2)
- power shell (1)
- wmi (3)
- mof (2)
- c# (1)
- concurrency (1)
- 劳动法 (1)
- 三国志游戏 (2)
- 三国 (1)
- 洪榕 (2)
- 金融投资知识 (1)
- motan (1)
- tkmybatis mapper (1)
- 工商注册信息查询 (1)
- consul (1)
- 支付业务知识 (2)
- 数据库备份 (1)
- 字段设计 (1)
- 字段 (1)
- dba (1)
- 插件 (2)
- PropEdit插件 (1)
- web工程 (1)
- 银行业知识 (2)
- 国内托管银行 (1)
- 数据库 (1)
- 事务 (2)
- git (18)
- component-scan (1)
- 私人 (0)
- db2 (14)
- alias (1)
- 住房 (1)
- 户口 (1)
- fastjson (1)
- test (6)
- RSA (2)
- 密钥 (1)
- putty (1)
- sftp (1)
- 加密 (1)
- 公钥私钥 (3)
- markdown (1)
- sweet (1)
- sourcetree (1)
- 好工具 (1)
- cmd (1)
- scp (1)
- notepad++ (1)
- ssh免密登录 (1)
- https (1)
- ssl (2)
- js (2)
- h2 (1)
- 内存 (2)
- 浏览器 (1)
- js特效 (1)
- io (1)
- 乱码 (1)
- 小工具 (1)
- 每周技术任务 (1)
- mongodb (7)
- 内存泄漏 (1)
- 码云 (2)
- 如何搭建java 视频服务器 tomcat (1)
- 资源 (1)
- 书 (1)
- 四色建模法 (1)
- 建模 (1)
- 配置 (1)
- 职位 (1)
- nginx (1)
- excel (1)
- log4j2 (2)
- 做菜 (1)
- jmap (1)
- jspwiki (1)
- activiti (1)
- 工作流引擎 (1)
- 安卓 (1)
- acitviti 例子 (1)
- 二维码 (1)
- 工作流 (1)
- powerdesign (2)
- 软件设计 (1)
- 乐观锁 (1)
- 王者荣耀 (1)
- session (2)
- token (5)
- cookie (4)
- springboot (24)
- jwt (2)
- 项目路径 (1)
- magicbook (1)
- requestType (1)
- json (2)
- swagger (1)
- eolinker (1)
- springdata (1)
- springmvc (1)
- controlleradvice (1)
- profile (1)
- 银行四要素 (1)
- 支付人员资源 (1)
- 支付渠道 (1)
- yaml (1)
- 中文编码 (1)
- mongo (2)
- serializable (1)
- 序列化 (1)
- zyd (1)
- unittest (1)
- 工具 (1)
- Something (1)
- 通达信 (1)
- protobuf (1)
- 算法 (1)
- springcloud (2)
- hikari (1)
- rocketmq (7)
- cachecloud (1)
- serfj (1)
- axure (1)
- lombok (1)
- 分布式锁 (1)
- 线程 (2)
- 同步代码块 (1)
- cobar (1)
- mq (1)
- rabbitmq (1)
- 定时执行 (1)
- 支付系统 (3)
- 唱歌 (1)
- elasticjob (1)
- 定时任务 (1)
- 界面 (1)
- flink (2)
- 大数据 (1)
- 接私活 (0)
- 内部培训 (2)
最新评论
-
dannyhz:
做股票从短线 试水,然后 慢慢发现 波段和 中期的故事可挖, ...
搭台唱戏 -
dannyhz:
http://developer.51cto.com/art/ ...
如何自己开发框架 它的注意点是什么
引用
两个线程 来改动 同一个 map里面的值, 在debug状态可以看到 , 只能同时一个线程 进行赋值, 因为有 writelock的 lock动作, 只有在一个lock 被unlock之后,才能另一线程 进入 进行修改。
同步阻塞
package com.base.concurrence.lock.reentrancereadwritelock; public class ReentrancelockClient { static LockBody lb = new LockBody(); public static void main(String[] args) { RunningTask rt1 = new RunningTask("FIRST", "RMB"); RunningTask rt2 = new RunningTask("FIRST", "GBP"); Thread t1 = new Thread(rt1); Thread t2 = new Thread(rt2); LockBody.Wallet wt_1 = new LockBody.Wallet(); wt_1.currency = "JPY"; // LockBody.Wallet wt_2 = new LockBody.Wallet(); // wt_2.currency = "USD"; lb.store("FIRST", wt_1); //lb.store("SECOND", wt_2); t1.start(); t2.start(); try { t1.join(); t2.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(lb.getVal("FIRST").currency); //System.out.println(lb.getVal("SECOND").currency); } static class RunningTask implements Runnable{ LockBody.Wallet newWt = new LockBody.Wallet(); String keyPoint, newCurrency; public RunningTask(String key, String currency){ keyPoint = key; newCurrency = currency; } @Override public void run() { lb.restore(keyPoint, newCurrency); } } }
package com.base.concurrence.lock.reentrancereadwritelock; import java.util.Map; import java.util.TreeMap; import java.util.concurrent.locks.ReentrantReadWriteLock; public class LockBody { ReentrantReadWriteLock lock = new ReentrantReadWriteLock(); public static Map<String, Wallet> mp = new TreeMap<String, Wallet>(); public void store(String key, Wallet wallet){ lock.writeLock().lock(); mp.put(key, wallet); lock.writeLock().unlock(); } public Wallet getVal(String key){ lock.readLock().lock(); Wallet wt = mp.get(key); lock.readLock().unlock(); return wt; } public void restore(String key, String currency){ Wallet wallet = getVal(key); lock.writeLock().lock(); wallet.currency = currency; lock.writeLock().unlock(); } public static class Wallet{ public String currency; } }
相关推荐
在这个例子中,`ReadWriteLockList`类维护了一个`LinkedList`,并使用`ReentrantReadWriteLock`来保护对链表的操作。添加和删除元素(写操作)都使用写锁,而读取元素(读操作)则使用读锁。这样,多个线程可以同时...
在这个例子中,`read()`方法获取读锁,`write()`方法获取写锁。在读锁和写锁的`finally`块中,我们释放了相应的锁,确保即使在异常情况下也能正确释放锁。 ### 6. 优化与注意事项 - **公平性**:`...
此外,还有其他的锁机制,如读写锁(`ReentrantReadWriteLock`),它允许多个线程同时读取但只允许一个线程写入,进一步优化了读操作的并发性能。还有条件锁(如`Condition`),它可以实现更复杂的同步逻辑。 了解...
在Java中,`java.util.concurrent.locks`包提供了`ReentrantReadWriteLock`类来实现可重入的读写锁。这个类包含两个核心方法:`readLock()`和`writeLock()`,分别用于获取读锁和写锁。读锁和写锁都是可重入的,这...
Java的`ReentrantReadWriteLock`和C++的`std::shared_mutex`是典型的读写锁实现。 5. **屏障(Barrier)**:线程到达屏障后必须等待所有其他线程也到达才能继续执行。Java的`java.util.concurrent.CyclicBarrier`和...
Java提供了多种同步机制,如synchronized关键字、Lock接口(ReentrantLock、ReentrantReadWriteLock)以及Semaphore信号量。synchronized用于方法或代码块,可以保证同一时间只有一个线程执行特定代码,避免数据冲突...
在Java中,ReadWriteLock这个接口就为我们实现了这个需求,通过他的实现类ReentrantReadWriteLock我们可以很简单的来实现刚才的效果。ReadWriteLock接口提供了两个锁:读锁和写锁。读锁允许多个线程同时访问资源,而...
在Java中,`ReentrantReadWriteLock`提供了读写锁,其中读锁就是一种共享锁。 死锁是并发编程中的一个严重问题,它发生在多个线程互相等待对方释放资源而无法继续执行的情况。死锁的四个必要条件包括:互斥、不可...
Java的`ReentrantReadWriteLock`提供这种功能,提高并发性能。 7. **分段锁**:当数据结构很大时,如ConcurrentHashMap,采用分段锁策略,将大锁分解为多个小锁,从而提高并发性。每个小锁只保护一部分数据,减少了...
- **例子**:在双重检查锁定(DCL)模式中,对象实例的构造过程必须保证不被重排序,以避免其他线程看到未完全初始化的对象。 **1.1.3 可见性** - **定义**:指当一个线程修改共享变量后,其他线程能够立即看到这...
- **Locks**:展示了如何使用内置的java.util.concurrent.locks包中的锁机制,如ReentrantLock、ReentrantReadWriteLock等。 - **Synchronized**:包含了使用`synchronized`关键字进行同步控制的示例,以及对监视...
在这个例子中,我们创建了一个`Data`类,其中包含了`ReadWriteLock`的实例。`write()`方法获取写锁并在持有锁期间执行写操作,`read()`方法获取读锁并进行读操作。`main()`方法创建了三个线程,一个用于写操作,两个...
ReentrantReadWriteLock lock = new ReentrantReadWriteLock(); Map, String> map = new HashMap(); public void put(String key, String value) { lock.writeLock().lock(); try { map.put(key, value); }...
ReadWriteLock lock = new ReentrantReadWriteLock(); Lock readLock = lock.readLock(); Lock writeLock = lock.writeLock(); // 获取写锁 writeLock.lock(); System.out.println("got the write lock"); /...
在这个例子中,`reader()`方法获取读锁并执行读取操作,`writer()`方法首先获取读者信号量以确保没有读者,然后获取写锁进行写入操作。最后,无论读写操作结束,都要释放相应的锁和信号量。 在实际应用中,还需要...
6. **读写锁**:在某些情况下,可能需要使用`ReentrantReadWriteLock`来区分读取(多个顾客同时等待)和写入(理发师服务顾客)操作,以提高并发性能。 7. **死锁预防**:避免死锁的关键是遵循死锁预防的四个必要...
在这个例子中,Semaphore用于限制同时进行的读取操作,当达到最大数量时,其他试图读取的线程将被阻塞,直到当前读取者完成并释放许可。 总的来说,解决Java中的读写器问题通常需要结合使用线程同步机制,如...
然而,实际的解决方案可能更复杂,需要考虑到更多的并发控制策略,例如使用信号量(Semaphore)或者读写锁(ReentrantReadWriteLock)。此外,还可以使用非阻塞的并发控制技术,如Java并发库中的`java.util....
在这个例子中,`readLock`用于通知监听器,而`writeLock`用于修改监听器列表。通过这种方式,多个线程可以同时通知监听器,只有在添加或移除监听器时才会阻塞其他线程。 总的来说,Java8提供了多种工具和设计模式来...
4. **读写锁优化**:结合ReentrantReadWriteLock,Semaphore可以用于优化读写锁,比如限制写操作的数量,而允许无限数量的读操作。 **四、示例代码** 下面是一个简单的Java Semaphore使用示例,模拟了一个只有两个...