您的位置:首页 > 编程语言 > Java开发

Java-多线程

2016-05-01 22:07 253 查看
1、如何创建线程以及线程的基本操作

创建线程两种方法:继承thread类,或者实现runnable接口

基本操作有:

启动线程start()(当调用start方法启动线程时,调用的是线程中的run方法,但是如果直接调用线程的run方法并不能启动线程)、

sleep(),让线程休眠

join(),让其他线程等待当前线程终止

yield(),当前运行线程释放处理器资源,让其它线程也可以抢占资源

currentThread():类函数,返回当前正在运行的线程引用

停止线程的方法有几种:(1)stop()方法,但是这种方法是直接结束线程,不管当前执行的线程是否执行完,这样可能会导致一些错误,比如清理还没有做完,所以不推荐使用

(2)interrupt()也可以中断线程,当调用该方法时,会 返回一个true的标志,但是如果之前线程有因为调用了sleep方法被阻塞时,再调用interrupt会并不会阻塞,而且会抛出中断异常。所以也不太适合,最好的中断线程的方法是设置旗标。

2、可见性及volatile关键字

volatile关键字可以保证线程可以正确的读取其他线程写入的值,通过修饰旗标值,可以实现结束线程的功能。

3、争用条件:女神周末约会的例子,当多个线程同时共享访问同一数据(内存单元)时,每个线程都尝试操作该数据,从而导致数据被破坏,这种现象称为争用条件

4、线程的互斥synchronized:变形金刚能量盒子的例子,互斥和同步往往是一起进行的,互斥是通过synchronized关键字实现的,将要操作的内存区放在加锁的块中

5、线程的同步wait/notify/notify all(唤醒所有线程):wait设置是防止线程条件不满足时不要一直占用着资源,所以让其等待着;然后在线程函数最后调用notifyall函数,当线程满足条件了就唤醒它们。

扩展:

Java Memory Mode

Locks & condition

线程的安全性:原子性与可见性、synchronized&volatile、deadlocks(死锁)

多线程常用的交互性模型:produce-consumer模型、read-write-lock模型、future模型、worker thread 模型(并发实现中有哪些类实现了这些模型)

java5中并发编程工具:线程池、callable&future、blockingQueue

推荐书目:

core Java、Java concurrency in practice
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: