多线程简单记录
线程的创建
- 继承自Thread
- 实现Runnable 。作为Thread的target,runnable实现了线程执行体,真正的线程对象还是Thread,只是该Thread线程负责执行其targer的run()
- 使用Callable和Future。 具有返回值并且可以抛出异常。作为target
线程的生命周期
- 新建状态
- 就绪状态
- 运行状态
- 阻塞状态
- 线程死亡
线程控制常用方法
- join 让一个线程等待另一个线程完成的方法。t.join().将会等到t执行完毕。
- 后台线程程(守护线程、精灵线程)。如果所有的前台线程都死亡,后台线程会自动死亡。可以将线程指定为守护线程
- 线程睡眠 睡眠的线程会进入阻塞状态,指定时间过去之后,会重新进入就绪状态,等待执行。
- 线程让步 也可以暂停当前线程,但是不会阻塞线程,该线程会转入就绪线程。暂停一下,系统的线程调度器重新调度一次,这个线程也可能会立即重新调度执行。并且只有与让步线程具有相同优先级,活着比让步线程优先级高的就绪状态线程才会获取执行的机会。
- 线程优先级 1-10 最小优先级 最大优先级 main具有普通优先级。
线程同步
线程同步解决多个线程同时访问同一个数据时可能出现的问题。比如银行取钱。多个线程同时取钱可能会出现错误。
- 同步代码块 同步监视器
- 同步方法 使用synchronized修饰某个方法,同步方法无需显示指定同步监视器,同步方法的同步监视器是this,也就是调用该方法的对象。当前类的实例。
- 同步锁 更加强大的线程同步机制。显示定义同步锁对象来实现同步。Lock。控制多个线程对共享资源进行访问的工具。锁提供了对共享资源的独占访问。每次只能有一个线程对Lock对象加锁,线程开始访问共享资源之前应先获取Lock对象。
线程通信
- 传统线程通信 线程通信需要使用到synchronized,配合对象的wait(),notify(),nitifyAll(),实现对象的通信。
- condition通信 如果代码中没有使用synchronized,而是显示使用了同步锁,没有wait(),notify(),notifyAll()可以使用,以及condition自身的await(),signal(),signalAll()方法。
- 阻塞队列线程通信 线程同步的工具,生产者向队列中存放(put)元素,如果队列已满,生产者线程阻塞,消费者从队列中取出(take)元素,如果队列已满,消费者线程阻塞。
对于线程通信,仿佛是需要先实现线程同步。