国产日韩欧美一区二区三区三州_亚洲少妇熟女av_久久久久亚洲av国产精品_波多野结衣网站一区二区_亚洲欧美色片在线91_国产亚洲精品精品国产优播av_日本一区二区三区波多野结衣 _久久国产av不卡

?

Java的多線程技術(shù)探討

2006-04-19 02:48張玉蓉藍(lán)雯飛
計(jì)算機(jī)教育 2006年4期
關(guān)鍵詞:隊(duì)列線程生命周期

張玉蓉 藍(lán)雯飛

摘要本文以Java的多線程為研究對象,闡述了Java線程的同步機(jī)制、模型及調(diào)度,討論了Java 在語言級對多線程的支持,并對Java環(huán)境下多線程程序的開發(fā)及應(yīng)用進(jìn)行了較深入的探討。

關(guān)鍵詞進(jìn)程線程同步Java

1 引言

Java是一種純面向?qū)ο蟮木幊陶Z言, 它除了具有可移植性、安全性、平臺無關(guān)性等優(yōu)點(diǎn)外,其內(nèi)置的多線程機(jī)制是傳統(tǒng)的C和C++所不具有的,Java虛擬機(jī)的很多任務(wù)都依賴線程調(diào)度。如能很好地利用線程,可以大大簡化應(yīng)用程序設(shè)計(jì),本文詳細(xì)探討了Java的多線程技術(shù)。

2 線程的相關(guān)概念

2.1線程與進(jìn)程的概念

進(jìn)程(Process)是應(yīng)用程序在內(nèi)存環(huán)境中基本的執(zhí)行單元。在Java中,進(jìn)程是有不同的地址空間且處在可執(zhí)行狀態(tài)中的應(yīng)用程序, 從用戶角度來看,進(jìn)程是應(yīng)用程序的一個執(zhí)行過程。線程(Thread)是指進(jìn)程中某個單一的順序控制流程。新興的操作系統(tǒng),如Mac、Windows NT等大多采用多線程的概念,把線程視為基本執(zhí)行單位。

2.2線程與進(jìn)程的區(qū)別

線程與進(jìn)程一樣,都有其執(zhí)行的開始、順序和結(jié)束, 執(zhí)行期間的任一時刻都有一個執(zhí)行點(diǎn)。進(jìn)程與線程的重要區(qū)別之一在于線程不能夠單獨(dú)執(zhí)行,它必須運(yùn)行在處于活動狀態(tài)的應(yīng)用程序進(jìn)程中,因此可以定義線程是程序內(nèi)部的具有并發(fā)性的順序代碼流。每個進(jìn)程都可以同時有執(zhí)行不同任務(wù)的多個線程。多線程的意義在于一個應(yīng)用程序的多個邏輯單元可以并發(fā)地執(zhí)行,但并不意味著多個用戶進(jìn)程在執(zhí)行,操作系統(tǒng)也不把每個線程作為獨(dú)立的進(jìn)程來分配獨(dú)立的系統(tǒng)資源。

線程與進(jìn)程區(qū)別之二在于二者的通信不同。進(jìn)程可以創(chuàng)建子進(jìn)程,父子進(jìn)程擁有不同的可執(zhí)行代碼和數(shù)據(jù)內(nèi)存空間,因此進(jìn)程間通信復(fù)雜,可能需要管道、消息隊(duì)列、共享內(nèi)存或信號處理來保證進(jìn)程間的通信,不僅費(fèi)時而且有限。而一個進(jìn)程中的各線程因?yàn)楣蚕淼刂房臻g, 所以它們之間的通信是非常簡單而有效的, 線程僅是過程調(diào)用,它們彼此獨(dú)立執(zhí)行,擁有獨(dú)立的執(zhí)行堆棧和程序執(zhí)行上下文。

2.3線程的生命周期及其狀態(tài)轉(zhuǎn)換

在Java語言中, 線程自創(chuàng)建后就處于其生命周期中, 程序可以對線程進(jìn)行各種控制操作,包括啟動、終止、掛起、恢復(fù)等, 相應(yīng)地, 線程在不同的生命階段因?yàn)閷ζ涫┘拥牟僮鞑煌陀胁煌臓顟B(tài)。圖1給出了線程可能的各種狀態(tài)以及從一個狀態(tài)轉(zhuǎn)化為另一種狀態(tài)時需要進(jìn)行的控制操作。Java線程在其生命周期中,共有五種線程狀態(tài), 如圖1所示。

(1) Newborn是線程已被創(chuàng)建但尚未執(zhí)行的狀態(tài)。此時線程對象已被分配內(nèi)存空間,其私有數(shù)據(jù)已被初始化,線程對象可通過start( ) 方法調(diào)度,或者利用stop( )方法取消,新創(chuàng)建的線程一旦被調(diào)度, 就將切換到Runnable狀態(tài)。

(2) Runnable是線程的就緒狀態(tài),表示線程正等待處理器資源,隨時等待處理機(jī)調(diào)度執(zhí)行。處于就緒狀態(tài)的線程事實(shí)上已被調(diào)度,線程依據(jù)自身優(yōu)先級進(jìn)入等待隊(duì)列,等待線程調(diào)度系統(tǒng)給分配CPU時間。處于就緒狀態(tài)的線程何時可真正執(zhí)行, 取決于線程優(yōu)先級以及隊(duì)列的當(dāng)前狀況。

猜你喜歡
隊(duì)列線程生命周期
基于云制造模式的產(chǎn)品碳足跡生命周期評價
處理器核心數(shù)量排行
隊(duì)列隊(duì)形體育教案
緩存淘汰算法研究
探索ASP.NET的生命周期
青春的頭屑
基于生命周期理論的科技型小微企業(yè)融資路徑選擇探析
稅收籌劃在企業(yè)經(jīng)營管理中的應(yīng)用探討
Java多線程產(chǎn)生安全問題及對策分析
采用ScheduledThreadPoolExecutor執(zhí)行定時重試任務(wù)時內(nèi)存溢出的分析及解決