- 進(jìn)程:自己獨(dú)有內(nèi)存空間霎挟,操作系統(tǒng)級(jí)別同時(shí)運(yùn)行多個(gè)任務(wù),每個(gè)任務(wù)相當(dāng)是一個(gè)應(yīng)用程序审残。進(jìn)程間切換很耗時(shí)
- 線程:是運(yùn)行在進(jìn)程上的梭域,一個(gè)進(jìn)程可以運(yùn)行多個(gè)線程,線程共享同一段內(nèi)存區(qū)域搅轿。線程間切換很快病涨,一個(gè)進(jìn)程中至少有一個(gè)線程在運(yùn)行。
時(shí)間片長(zhǎng)短不一定璧坟,分配給哪些線程也不一定既穆。
thread每一個(gè)類描述一個(gè)線程
run方法定義線程要完成的任務(wù)
start方法用于啟動(dòng)線程,使其可以并發(fā)運(yùn)行
如果兩個(gè)任務(wù)運(yùn)行是有先后順序的雀鹃,我們稱為同步的幻工。
如果是各自做各自的,我們稱為異步的黎茎。
同步一般發(fā)生在同一線程中囊颅,異步是在多線程中完成。
使用Runnable的好處
- 降低耦合
- 可以實(shí)現(xiàn)多繼承
Thread current = Thread.currentThread();
用于獲取運(yùn)行當(dāng)前代碼片段的線程
當(dāng)程序運(yùn)行起來(lái)是傅瞻,OS會(huì)啟動(dòng)一個(gè)進(jìn)程來(lái)運(yùn)行JVM
而進(jìn)程啟動(dòng)后會(huì)創(chuàng)建一個(gè)線程踢代,用這個(gè)線程來(lái)運(yùn)行main方法
long getID() 返回該線程的標(biāo)識(shí)符
String getName() 返回線程的名稱
int getPriority() 返回線程的優(yōu)先級(jí),默認(rèn)是5
Thread.state.getState() 返回線程的狀態(tài)
boolean isAlive() 測(cè)試線程是否處于活動(dòng)狀態(tài)
boolean isDaemon() 測(cè)試線程是否為守護(hù)線程
boolean isInterrupted() 測(cè)試線程是否已經(jīng)中斷
void setPriority(int priority)設(shè)置線程優(yōu)先級(jí)
守護(hù)線程也叫后臺(tái)線程
void setDaemon(boolean)當(dāng)為true時(shí)該線程為守護(hù)線程
進(jìn)程中嗅骄,所有前臺(tái)線程結(jié)束胳挎,守護(hù)線程強(qiáng)制結(jié)束
GC就是運(yùn)行中守護(hù)線程上的
static void sleep(long ms)
用于使當(dāng)前線程進(jìn)入阻塞狀態(tài),阻塞時(shí)間到了掸读,使線程進(jìn)入Runnable狀態(tài)串远,并非Running狀態(tài)宏多,所以可能存在誤差
static void yield() 用于當(dāng)前線程主動(dòng)讓出CPU時(shí)間片回到Runnable狀態(tài)
void join() 用于等待當(dāng)前線程結(jié)束
多線程并發(fā)訪問(wèn)同一數(shù)據(jù)時(shí),會(huì)產(chǎn)生線程安全問(wèn)題
解決辦法就是把異步操作變?yōu)橥讲僮?/p>
被synchronized修飾的方法被稱為同步方法
synchronize塊用于同步某一代碼片段的澡罚,通常范圍小于修飾方法
當(dāng)一個(gè)類中伸但,多個(gè)方法被synchronized修飾時(shí),這些方法就是互斥的留搔,多個(gè)方法不允許同時(shí)執(zhí)行
同步代碼塊
synchronized(同步監(jiān)視器-鎖對(duì)象引用){
//代碼塊
}
使用同步塊可以縮小同步范圍更胖,提升并發(fā)效率,所對(duì)象通常是this
靜態(tài)方法鎖
public synchronized static void xxx(){……}
靜態(tài)方法上鎖后隔显,同步是跨對(duì)象的却妨。
wait:在當(dāng)前對(duì)象上阻塞
notify:調(diào)用對(duì)象的notify方法,可以該對(duì)象上等待的線程解除阻塞
try {
//在Object對(duì)象上等待
synchronized (object) {
/*
* wait方法要求
* 調(diào)用那個(gè)對(duì)象的wait方法就要將該對(duì)象加鎖
*/
object.wait();//wait是無(wú)限期等待
}
} catch (InterruptedException e) {
e.printStackTrace();
}
Collections可以將集合轉(zhuǎn)換為線程安全的
線程池:
控制線程數(shù)量
重用線程
Executors.newCachedThreadPool() 根據(jù)需求創(chuàng)建線程括眠,彈性好
Executor.newFixedThreadPool(int NThreads) 固定大小線程池
Executors.newScheduledThreadPoll(int corePoolSize) 可延遲運(yùn)行任務(wù)
Executors.newSingleThreadExecutor() 單worker線程池
BlockingQueqe 雙緩沖隊(duì)列彪标,存取可以異步,存取本身還是同步的
ArrayBlockingQueue 規(guī)定大小的BlockingDuque掷豺,指明大小
LinkedBlockingQueue 不定長(zhǎng)的BlockingDuque捞烟,可規(guī)定大小
PoriorityBlockingDuque 規(guī)定大小,誰(shuí)小出誰(shuí)
SynchronizeQueue当船,只能放一個(gè)元素题画,放取交替進(jìn)行