posted @ 2017-02-13 15:50 文轶 阅读(224) 评论(0) 推荐(0) 编辑
摘要:
前言 Java多线程分类中写了21篇多线程的文章,21篇文章的内容很多,个人认为,学习,内容越多、越杂的知识,越需要进行深刻的总结,这样才能记忆深刻,将知识变成自己的。这篇文章主要是对多线程的问题进行总结的,因此罗列了40个多线程的问题。 这些多线程的问题,有些来源于各大网站、有些来源于自己的思考。 阅读全文
摘要:
设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。 毫无疑问,设计模式于己于他人于系统都是多赢的, 阅读全文
posted @ 2017-02-13 15:47 文轶 阅读(131) 评论(0) 推荐(0) 编辑
摘要:
0.参考文献 http://blog.csdn.net/liulin_good/article/details/6213815 1.java集合类图 1.1 1.2 上述类图中,实线边框的是实现类,比如ArrayList,LinkedList,HashMap等,折线边框的是抽象类,比如Abstrac 阅读全文
posted @ 2017-02-13 15:18 文轶 阅读(4475) 评论(1) 推荐(0) 编辑
摘要:
一、为什么要编码? 由于人类的语言太多,因而表示这些语言的符号太多,无法用计算机的一个基本的存储单元 byte来表示,因而必须要经过拆分或一些翻译工作,才能让计算机能理解。 byte一个字节即8个bit,所以能表示的字符范围是0~255个,这满足不了人类的需要,要解决这个矛盾必须需要一个新的数据结构 阅读全文
posted @ 2017-02-13 15:15 文轶 阅读(3735) 评论(0) 推荐(0) 编辑
摘要:
本文将用到Java内存模型的happens-before偏序关系(下文将简称为hb)以及ConcurrentHashMap的底层模型相关的知识。happens-before相关内容参见:JLS §17.4.5. Happens-before Order、深入理解Java内存模型以及Happens b 阅读全文
posted @ 2017-02-13 15:10 文轶 阅读(1651) 评论(0) 推荐(0) 编辑
摘要:
ConcurrentHashMap完全允许多个读操作并发进行,读操作并不需要加锁。(事实上,ConcurrentHashMap支持完全并发的读以及一定程度并发的写。)如果使用传统的技术,如HashMap中的实现,如果允许可以在hash链的中间添加或删除元素,读操作不加锁将得到不一致的数据。但是Con 阅读全文
posted @ 2017-02-13 15:04 文轶 阅读(2948) 评论(0) 推荐(0) 编辑
摘要:
术语定义 线程不安全的HashMap 因为多线程环境下,使用Hashmap进行put操作会引起死循环,导致CPU利用率接近100%,所以在并发情况下不能使用HashMap。如以下代码: 01 final HashMap<String, String> map = new HashMap<String 阅读全文
posted @ 2017-02-13 15:01 文轶 阅读(15218) 评论(0) 推荐(2) 编辑
摘要:
本文是作者原创,首发于InfoQ:http://www.infoq.com/cn/articles/ConcurrentLinkedQueue 1. 引言 在并发编程中我们有时候需要使用线程安全的队列。如果我们要实现一个线程安全的队列有两种实现方式一种是使用阻塞算法,另一种是使用非阻塞算法。使用阻塞 阅读全文
posted @ 2017-02-13 14:56 文轶 阅读(839) 评论(0) 推荐(0) 编辑
摘要:
Copy-On-Write简称COW,是一种用于程序设计中的优化策略。其基本思路是,从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候,才会真正把内容Copy出去形成一个新的内容然后再改,这是一种延时懒惰策略。从JDK1.5开始Java并发包里提供了两个使用CopyOnWrite机制实现 阅读全文
posted @ 2017-02-13 14:54 文轶 阅读(234) 评论(0) 推荐(0) 编辑