首页 > 技术文章 > 多线程概念

quchunhui 2016-08-02 17:26 原文

参考源:http://www.imooc.com/video/4241

====什么是进程?

程序(任务)的执行过程,它持有资源(共享内存,共享文件)和线程

 

====什么是线程?

线程是系统中最小的执行单元

同一进程中有多个线程

线程共享进程的资源

作为计算机处理器,在同一时间,同一个处理器(或者叫同一个核)只能运行一条线程

 

====线程的交互

 

====Java对线程的支持

主要体现在class Thread这个类和interface Runnable这个接口之上,他们都寄生于java.lang包。

具体区别可以参考下面的一篇博客:

http://developer.51cto.com/art/201203/321042.htm

 

====线程错误退出

错误的退出方法:直接使用stop()方法

 

====线程的正确退出

使用线程退出的标志。

 

====广为流传的错误退出方法

1)使用interrupt()方法

interrupt()方法的初衷并不事用于停止线程。用于中断线程。

 

 

====线程交互

--什么是争用条件?

当多个线程同时共享访问同一数据(内存区域)时,每个线程都尝试操作该数据,从而导致数据被破坏(corrupted),这种现象称为争用条件。

如上图中,线程1转移500,线程2转移900至energyBox中,预想转移后应该为6400,实际却是550。

 

--互斥与同步

互斥的实现:synchronized(intrinsic lock)

同步的实现:wait()/notify()/notifyAll()

 

====什么是线程锁:

三个和尚打水喝!打个比喻就是锁。拿到桶的人不会渴死,

多线程就是你拿一会,我拿一会,

线程等待就是一个和尚喝了一会,别的和尚在等,可能能喝到水。

死锁就是三个和尚互相打架,都拽着对方的手谁都喝不到。

睡眠就是一个和尚说我可以让别人先喝,自己去睡会觉去,回来后还得看别人的脸色。

推荐阅读