http://www.cnblogs.com/skywang12345/p/java_threads_category.html
http://blog.csdn.net/hbtj_1216/article/details/77648610
继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。
http://blog.csdn.net/hbtj_1216/article/details/76256149
http://blog.csdn.net/hbtj_1216/article/details/76282462
http://blog.csdn.net/hbtj_1216/article/details/77866384
http://blog.csdn.net/hbtj_1216/article/details/77067467
http://blog.csdn.net/hbtj_1216/article/details/75162088
http://blog.csdn.net/hbtj_1216/article/details/70569881
http://blog.csdn.net/hbtj_1216/article/details/72026927
http://blog.csdn.net/hbtj_1216/article/details/72148322
http://www.jianshu.com/p/3a196baa227b
http://www.jianshu.com/p/f4ed71560771
(1)使用规则:http://www.cnblogs.com/skywang12345/p/3479202.html
(2)synchronized 底层实现原理: http://blog.csdn.net/hbtj_1216/article/details/77773292
http://www.cnblogs.com/dolphin0520/p/3923167.html
synchronized和Lock有以下几点不同:
Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现。
synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁。
Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断。
通过Lock可以知道有没有成功获取锁(tryLock()方法尝试获取锁),而synchronized却无法办到。
Lock可以提高多个线程进行读操作(读锁是共享锁)的效率。
http://blog.csdn.net/hbtj_1216/article/details/76263513
http://www.cnblogs.com/greta/p/5624839.html
http://www.cnblogs.com/onlywujun/p/3565082.html
产生死锁的四个必要条件:
http://blog.csdn.net/hbtj_1216/article/details/75171213
守护线程是为其他线程的运行提供服务的线程。
setDaemon(boolean on)方法可以方便的设置线程的Daemon模式,true为守护模式,false为用户模式。
http://www.jianshu.com/p/87bff5cc8d8c
http://www.cnblogs.com/dolphin0520/p/3932921.html
Running、ShutDown、Stop、Tidying、Terminated
http://blog.csdn.net/l_kanglin/article/details/57411851
http://blog.csdn.net/hbtj_1216/article/details/77505409
http://cmsblogs.com/?p=1175
备用地址:http://blog.csdn.net/chenssy/article/details/32703499
http://cmsblogs.com/?p=2235
备用地址:http://blog.csdn.net/chenssy/article/details/69640293
CAS实际上是利用处理器提供的CMPXCHG指令实现的,而处理器执行CMPXCHG指令是一个原子性操作。
http://www.jianshu.com/p/d8eeb31bee5c
【死磕Java并发】—–J.U.C之AQS:AQS简介
http://cmsblogs.com/?p=2174
备用地址:http://blog.csdn.net/chenssy/article/details/60479594
【死磕Java并发】—–J.U.C之AQS:CLH同步队列
http://cmsblogs.com/?p=2188
备用地址:http://blog.csdn.net/chenssy/article/details/60781148
【死磕Java并发】—–J.U.C之AQS:同步状态的获取与释放
http://cmsblogs.com/?p=2197
备用地址:http://blog.csdn.net/chenssy/article/details/61922603
【死磕Java并发】—–J.U.C之AQS:阻塞和唤醒线程
http://cmsblogs.com/?p=2205
备用地址:http://blog.csdn.net/chenssy/article/details/65449785
http://www.jianshu.com/p/4358b1466ec9
http://cmsblogs.com/?p=2213
备用地址:http://blog.csdn.net/chenssy/article/details/68059443
http://cmsblogs.com/?p=2253
备用地址:http://blog.csdn.net/chenssy/article/details/70657913
http://cmsblogs.com/?p=2241
备用地址:http://blog.csdn.net/chenssy/article/details/70160595
http://cmsblogs.com/?p=2263
备用地址:http://blog.csdn.net/chenssy/article/details/71132566
ConcurrentHashMap源码分析——JDK1.7:http://blog.csdn.net/hbtj_1216/article/details/76205903
ConcurrentHashMap源码分析——JDK1.8 : http://www.jianshu.com/p/c0642afe03e0
ConcurrentHashMap1.7和1.8的不同实现 : http://www.jianshu.com/p/e694f1e868ec
CAS(Compare And Swap)详解: http://www.jianshu.com/p/fb6e91b013cc
ArrayBlockingQueue源码解析——JDK1.8 http://www.cnblogs.com/leesf456/p/5533770.html
LinkedBlockingQueue源码解析——JDK1.8 http://www.cnblogs.com/leesf456/p/5539071.html
SynchronousQuene
http://blog.csdn.net/chenssy/article/details/77371992
priorityBlockingQuene
http://blog.csdn.net/hbtj_1216/article/details/77161198
http://blog.csdn.net/hbtj_1216/article/details/77161506
http://www.cnblogs.com/skywang12345/p/3514593.html#a2
http://www.cnblogs.com/skywang12345/p/3514604.html
http://www.cnblogs.com/skywang12345/p/3514623.html