缓存是集合框架HashMap怎么做?

2)缓存是集合框架  (视频下载) (全部书籍)

马克-to-win:在 实践当中,有很多数据并不是像火车票数或者账户余额这样的关键数据(存在的意义就是为了疯狂的加减,疯狂的变化)。它们只是普通数据库表的一个缓存而已。 比如淘宝网中展示的衣服数据,基本不变,即使变了,不实时准确的展示最新的,也不会引起灾难性的后果,不像银行账户或火车票数。马克-to-win:这种数据我们就考虑放在集 合框架当中。我们的备选方案有1)Hashtable,2)HashMap,3)Collections.synchronizedMap(new HashMap())或4)ConcurrentHashMap()。

i)HashTable:
 
马克-to-win:HashTable本身是 synchronized。换句话说,HashTable的类里面用很多synchronized关键字来保证线程安全。在高并发情况下, HashTable的效率非常低下。另外,一个线程往Hashtable添加(put)元素,同时另一个线程读数据会引起 ConcurrentModificationException异常。这叫fast-fail(快速失败,失败越快,错误越小)

详情请见:http://www.mark-to-win.com/index.html?content=Jsp/jspUrl.html&chapter=Jsp/jsp7_web.html#CompareCollectionInConcurrent

猜你喜欢

转载自blog.csdn.net/mark_to_win/article/details/85015561
今日推荐