Java多線程——基礎(chǔ)概念
java多線程
并發(fā)與并行:
并行: 指兩個(gè)或多個(gè)事件在同一時(shí)刻發(fā)生 ( 同時(shí)發(fā)生 ) 。
并發(fā): 指兩個(gè)或多個(gè)事件在同一個(gè)時(shí)間段內(nèi)發(fā)生。
多線程使用場景:
1. 后臺(tái)任務(wù),比如游戲服務(wù)器
2.定時(shí)向大量用戶(100W)用戶發(fā)郵件
3.異步處理: 發(fā)微博/記錄日志等
4.分布式計(jì)算...
線程和進(jìn)程區(qū)別:
進(jìn)程:是指一個(gè)內(nèi)存中運(yùn)行的應(yīng)用程序,每個(gè)進(jìn)程都有一個(gè)獨(dú)立的內(nèi)存空間,一個(gè)應(yīng)用程序可以同時(shí)運(yùn)行多 個(gè)進(jìn)程;進(jìn)程也是程序的一次執(zhí)行過程,是系統(tǒng)運(yùn)行程序的基本單位;系統(tǒng)運(yùn)行一個(gè)程序即是一個(gè)進(jìn)程從創(chuàng) 建、運(yùn)行到消亡的過程。
線程:進(jìn)程內(nèi)部的一個(gè)獨(dú)立執(zhí)行單元;一個(gè)進(jìn)程可以同時(shí)并發(fā)的運(yùn)行多個(gè)線程,可以理解為一個(gè)進(jìn)程便相當(dāng) 于一個(gè)單 CPU 操作系統(tǒng),而線程便是這個(gè)系統(tǒng)中運(yùn)行的多個(gè)任務(wù)。
創(chuàng)建線程的方式:
繼承Thread類
1) 定義子類繼承Thread類。
2) 子類中重寫Thread類中的run方法。
3) 創(chuàng)建Thread子類對(duì)象,即創(chuàng)建了線程對(duì)象。
4) 調(diào)用線程對(duì)象start方法:啟動(dòng)線程,調(diào)用run方法。
Thread類的有關(guān)方法:
void start()
: 啟動(dòng)線程,并執(zhí)行對(duì)象的run()方法
run()
: 線程在被調(diào)度時(shí)執(zhí)行的操作
String getName()
: 返回線程的名稱
void setName(String name)
:設(shè)置該線程名稱
static Thread currentThread()
: 返回當(dāng)前線程。在Thread子類中就是this,通常用于主線程和Runnable實(shí)現(xiàn)類
static void yield()
:線程讓步
暫停當(dāng)前正在執(zhí)行的線程,把執(zhí)行機(jī)會(huì)讓給優(yōu)先級(jí)相同或更高的線程
若隊(duì)列中沒有同優(yōu)先級(jí)的線程,忽略此方法
join()
:當(dāng)某個(gè)程序執(zhí)行流中調(diào)用其他線程的 join() 方法時(shí),調(diào)用線程將被阻塞,直到 join() 方法加入的 join 線程執(zhí)行完為止 低優(yōu)先級(jí)的線程也可以獲得執(zhí)行
static void sleep(long millis)
:(指定時(shí)間:毫秒)
令當(dāng)前活動(dòng)線程在指定時(shí)間段內(nèi)放棄對(duì)CPU控制,使其他線程有機(jī)會(huì)被執(zhí)行,時(shí)間到后重排隊(duì)。
拋出InterruptedException異常
l stop():
強(qiáng)制線程生命期結(jié)束,不推薦使用
boolean isAlive():
返回boolean,判斷線程是否還活著
線程的同步:
模擬火車站售票程序
線程的同步:synchronized
解決辦法:
對(duì)多條操作共享數(shù)據(jù)的語句,讓一個(gè)線程都執(zhí)行完,執(zhí)行過程中,其他線程不可以參與執(zhí)行。
Java對(duì)于多線程的安全問題提供了專業(yè)的解決方式:同步機(jī)制
1. 同步代碼塊:
synchronized (對(duì)象){ // 需要被同步的代碼; }
2. synchronized還可以放在方法聲明中,表示整個(gè)方法為同步方法。
例如:
public synchronized void show (String name){ ....... }
總結(jié)
本篇文章就到這里了,希望可以給你帶來一些幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
使用Shiro實(shí)現(xiàn)登錄成功后跳轉(zhuǎn)到之前的頁面
這篇文章主要介紹了如何使用Shiro實(shí)現(xiàn)不同用戶登錄成功后跳轉(zhuǎn)到不同主頁,實(shí)現(xiàn)此功能目前比較好的方法是用ajax的方法登錄,第二種方法是把用戶未登錄前的url存在session中,需要的朋友可以參考下2015-07-07Java?關(guān)鍵字break和continue的使用說明
這篇文章主要介紹了Java?關(guān)鍵字break和continue的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03SSH框架網(wǎng)上商城項(xiàng)目第11戰(zhàn)之查詢和刪除商品功能實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了SSH框架網(wǎng)上商城項(xiàng)目第11戰(zhàn)之查詢和刪除商品功能實(shí)現(xiàn)的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06Springcloud整合stream,rabbitmq實(shí)現(xiàn)消息驅(qū)動(dòng)功能
官方定義SpringCloud?Stream?是一個(gè)構(gòu)建消息驅(qū)動(dòng)微服務(wù)的框架。我們只需要搞清楚如何與Spring?Cloud?Stream?交互就可以方便使用消息驅(qū)動(dòng)的方式。本文將通過Springcloud整合stream,rabbitmq實(shí)現(xiàn)消息驅(qū)動(dòng)功能,需要的可以參考一下2022-02-02java加載properties文件的六種方法總結(jié)
這篇文章主要介紹了java加載properties文件的六種方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-05-05win7 64位系統(tǒng)JDK安裝配置環(huán)境變量教程
這篇文章主要為大家詳細(xì)介紹了win7 64位系統(tǒng)JDK安裝配置環(huán)境變量教程,感興趣的小伙伴們可以參考一下2016-06-06