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
创建线程两种方法:继承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
相关文章推荐
- 让myeclipse的XML文件在编辑时可以产生提示
- S2SH开发中的Error-映射错误
- 安卓开发之java基础笔记【2】
- Java中的集合功能整理
- JAVA SkipList 跳表 的原理和使用例子
- 码农小汪-SpringMVC-入门篇
- 讲义五 java语言基础
- java正则表达式
- LeetCode------Roman to Integer
- java_Java工具包(Arrays,Date,SimpleDateFormat,NumberFormat,DecimalFormat,Calendar,Math)
- springmvc框架简介,第一个demo
- java,jdbc连接mysql
- java静态分配和动态分配
- java第四次实验
- java_包
- java热部署及类加载
- 20145214 《Java程序设计》第9周学习总结
- JAVA语言之计数排序
- JAVA中的集合的概念
- Java jvm 内存回收机制