一. 基本概念介绍
1. 线程是系统中最小的执行单元。
2. 同一进程中有多个线程。
3. 线程共享进程的资源。
4. 线程的交互
4.1. 互斥
2.2. 同步
二. java线程初体验
2.1 java语言对线程的支持
Thread类和Runnable接口,它们共有的方法是run()。
三. java线程的正确停止
线程停止的错误方法是stop()和interrupt()。
正确的是设置退出旗标。
四. 线程交互
争用条件:当多个线程同时共享访问同一数据(内存区域)时,每个线程都尝试操作该数据,从而导致数据被破坏,这种现象称为争用条件。
解决:互斥&同步
互斥的实现:synchronized(intrinsic lock)
同步的实现:wait()/notify()/notifyAll()(object对象的成员函数)
互斥:是指某一资源同时只允许一个访问者对其进行访问,具有唯一性和排它性。但互斥无法限制访问者对资源的访问顺序,即访问是无序的。 同步:是指在互斥的基础上(大多数情况),通过其它机制实现访问者对资源的有序访问。在大多数情况下,同步已经实现了互斥,特别是所有写入资源的情况必定是互斥的。少数情况是指可以允许多个访问者同时访问资源。
五. 进阶展望
如何扩展Java并发的知识:
JVM描述了Java线程如何通过内存进行交互
happen-before
synchronized,volatile&final
Locks&Condition:
Java锁机制和等待条件的高层实现
java.util.concurrent.locks
线程安全性:
原子性和可见性
java.util.concurrent.atomic
synchronized&volatile
DeadLocks
多线程常用的交互模型:
Producer-Consumer模型
Read-Write Lock模型
Future模型
Worker Thread模型
java5中并发编程工具:
都位于java.util.concurrent包之下
线程池ExecutorService
Callable&Future
BlockingQueue