網(wǎng)絡(luò)編程技術(shù)論文
網(wǎng)絡(luò)編程技術(shù)論文
科學(xué)技術(shù)的不斷發(fā)展推動(dòng)了網(wǎng)絡(luò)信息化時(shí)代的發(fā)展,隨著計(jì)算機(jī)技術(shù)不斷的發(fā)展,各種網(wǎng)絡(luò)編程技術(shù)日新月異。下面是由學(xué)習(xí)啦小編整理的網(wǎng)絡(luò)編程技術(shù)論文,謝謝你的閱讀。
網(wǎng)絡(luò)編程技術(shù)論文篇一
Java多線程技術(shù)的網(wǎng)絡(luò)編程探討
摘 要:作為Java中的主要應(yīng)用型技術(shù),多線程技術(shù)具有并行機(jī)制、交互性能和實(shí)時(shí)控制等特征。因此,它具有強(qiáng)大的安全性能,并據(jù)此而被廣泛應(yīng)用在網(wǎng)絡(luò)編程當(dāng)中。因此,本文將圍繞Java多線程技術(shù)展開(kāi)進(jìn)一步的討論,首先針對(duì)其進(jìn)行了簡(jiǎn)單的介紹,讓人們對(duì)此有一個(gè)較為清晰的了解,然后分析了如何在網(wǎng)絡(luò)編程中應(yīng)用Java的多線程技術(shù)進(jìn)行編程,從而使得編程開(kāi)發(fā)人員可以有效提高程序運(yùn)行的效率。
關(guān)鍵詞:Java;多線程技術(shù);網(wǎng)絡(luò)編程
中圖分類(lèi)號(hào):TP311.1
由SUN公司開(kāi)發(fā)的一種全新的計(jì)算概念Java,它首先是一種程序設(shè)計(jì)語(yǔ)言,具有較大的安全性能,并能夠最大限度的利用網(wǎng)絡(luò)進(jìn)行程序的傳輸。因此,Java是當(dāng)前適合于分布式計(jì)算的一種新生代網(wǎng)絡(luò)應(yīng)用開(kāi)發(fā)語(yǔ)言。由于Java提供了很多系統(tǒng)性模塊來(lái)支持基于TCP/IP協(xié)議的編程,因此,它在訪問(wèn)網(wǎng)絡(luò)資源的時(shí)候,就像存取本地文件一樣方便快捷。因此,我們將在本文中具體探討下Java多線程技術(shù)在網(wǎng)絡(luò)編程中的具體應(yīng)用,從而讓人更好的理解其可移植性、健壯性、安全性等很高的性能。
1 Java多線程技術(shù)概述
Java設(shè)計(jì)語(yǔ)言的思想基礎(chǔ)就是當(dāng)前的大部分操作系統(tǒng)都已經(jīng)實(shí)現(xiàn)了多線程調(diào)度。因此,Java虛擬機(jī)都可以對(duì)類(lèi)庫(kù)進(jìn)行多線程設(shè)計(jì)。一般來(lái)說(shuō),多線程就是指計(jì)算機(jī)運(yùn)行程序時(shí)所具有的多個(gè)控制流。即使是最簡(jiǎn)單的Applet,它也是由多個(gè)線程來(lái)共同完成的。因此,我們說(shuō),Java語(yǔ)言支持應(yīng)用程序進(jìn)程內(nèi)部的多個(gè)執(zhí)行線程的并發(fā)執(zhí)行。在這樣一個(gè)多線程程序中,它可以分配一個(gè)線程來(lái)讀取相關(guān)的數(shù)據(jù),同時(shí)讓另外一個(gè)線程來(lái)對(duì)數(shù)據(jù)進(jìn)行處理,又讓第三個(gè)線程把數(shù)據(jù)傳輸?shù)綀D形卡上去。這三個(gè)線程可以共同運(yùn)行。那么,我們就會(huì)發(fā)現(xiàn),數(shù)據(jù)讀取的同時(shí),還可以處理數(shù)據(jù),即大大提高了程序的運(yùn)行性能。
Java的這種多線程技術(shù),其線程屬性也是較為特殊的。我們要想了解其并更好的使用其,就應(yīng)該對(duì)Java實(shí)時(shí)系統(tǒng)等有一個(gè)較為全面且清晰的了解,還要更多的了解線程體、線程的生命周期、線程組、幽靈線程等。由于所有操作都是發(fā)生在線程體中,我們應(yīng)該分解出幾種不同的線程狀態(tài),即新線程狀態(tài)、可運(yùn)行狀態(tài)、非運(yùn)行狀態(tài)。而線程調(diào)度是JVM對(duì)運(yùn)行的多個(gè)線程進(jìn)行系統(tǒng)級(jí)的協(xié)調(diào),數(shù)字越大表明線程的級(jí)別越高。一般來(lái)說(shuō),Java將線程的優(yōu)先級(jí)分為10個(gè)等級(jí),分別使用了分別用1-10的數(shù)字進(jìn)行標(biāo)示。其中,高優(yōu)先級(jí)的線程會(huì)在低優(yōu)先級(jí)線程之前得到執(zhí)行,優(yōu)先級(jí)相同的線程則會(huì)采用輪轉(zhuǎn)的方式來(lái)分配CPU時(shí)間片。此外,在Java中,每一個(gè)線程都可以成為幽靈線程,它是應(yīng)用中典型的獨(dú)立線程,其方法一般是通過(guò)無(wú)限循環(huán)來(lái)等待服務(wù)請(qǐng)求。而Java線程中的每一個(gè)都是線程組中的成員,這些不同的線程組會(huì)提供一種機(jī)制來(lái)讓多種線程集中到一個(gè)對(duì)象內(nèi)部,并對(duì)它們進(jìn)行整體控制與操作。Java線程的實(shí)現(xiàn)往往是依據(jù)多線程應(yīng)用程序繼承或?qū)崿F(xiàn)對(duì)象的不同,采取線程類(lèi)Thread和Runnable接口兩種方式來(lái)實(shí)現(xiàn)的。應(yīng)該來(lái)說(shuō),Java多線程技術(shù),有著自身的優(yōu)勢(shì)和劣勢(shì)。就優(yōu)勢(shì)來(lái)說(shuō),它能夠帶來(lái)更好的交互性能和實(shí)時(shí)控制性能,還具有更快的程序響應(yīng)速度。當(dāng)沒(méi)有處理任務(wù)出現(xiàn)的時(shí)候,它可以把處理器的時(shí)間分配給其他方面的任務(wù),還可以隨時(shí)停止任務(wù),進(jìn)而將各個(gè)任務(wù)進(jìn)行優(yōu)化。但是,它也有著一定的劣勢(shì),即當(dāng)在進(jìn)行資源共享時(shí),其程序運(yùn)行的速度較慢,還對(duì)線程管理要消耗額外的CPU開(kāi)銷(xiāo),甚至還會(huì)產(chǎn)生死鎖等多線程的不良癥狀。
2 Java多線程技術(shù)的網(wǎng)絡(luò)編程具體應(yīng)用
Java多線程技術(shù)在網(wǎng)絡(luò)編程中的具體應(yīng)用,其實(shí)質(zhì)就是指將程序任務(wù)分成幾個(gè)并行的子任務(wù)分別進(jìn)行的編程。事實(shí)上,對(duì)于Java來(lái)說(shuō),我們把多線程機(jī)制蘊(yùn)含在語(yǔ)言設(shè)計(jì)中是其最為顯著也是最為重要的一個(gè)特征。在每一個(gè)進(jìn)程中,都有多個(gè)線程。這些線程在操作系統(tǒng)的共同調(diào)度下實(shí)現(xiàn)了并發(fā)執(zhí)行,可以占有整個(gè)系統(tǒng)性資源。那么,為了減少并發(fā)程序設(shè)計(jì)的困難,提高多線程應(yīng)用程序的執(zhí)行效率,我們應(yīng)該把Java多線程技術(shù)應(yīng)用到編程當(dāng)中去,從而使得程序開(kāi)發(fā)人員可以利用多線程編程接口來(lái)寫(xiě)出支持多線程的應(yīng)用程序。事實(shí)上,Java在網(wǎng)絡(luò)編程方面的功能是非常強(qiáng)大的,它可以使得Java的小程序能在網(wǎng)絡(luò)上完全地傳送和運(yùn)行,還可以擴(kuò)充Web服務(wù)器功能的Servlet等技術(shù),并監(jiān)聽(tīng)客戶(hù)端的連接請(qǐng)求和響應(yīng)連接,這些都是其廣泛流行的主要原因所在。
那么,Java多線程技術(shù)如何在網(wǎng)絡(luò)編程中實(shí)現(xiàn)具體應(yīng)用呢?具體來(lái)說(shuō),我們應(yīng)該首先建立服務(wù)器類(lèi)的try。這是因?yàn)榉?wù)器是客戶(hù)/服務(wù)器模型中業(yè)務(wù)過(guò)程處理的核心所在,我們要能夠使得在出現(xiàn)異常服務(wù)時(shí),能夠及時(shí)多個(gè)請(qǐng)求同時(shí)到達(dá)服務(wù)器的情況。一般來(lái)說(shuō),我們有兩種服務(wù)會(huì)等待用戶(hù)連接器實(shí)現(xiàn)方案,即并發(fā)服務(wù)器和反復(fù)服務(wù)器。其中,前者有一個(gè)接收用戶(hù)連接請(qǐng)求點(diǎn)時(shí)隨系統(tǒng)啟動(dòng)而產(chǎn)生的一個(gè)守護(hù)線程,后者則是并發(fā)服務(wù)器實(shí)現(xiàn)的關(guān)鍵所在。其次,我們還應(yīng)該在建立服務(wù)器線程類(lèi)中,按照先來(lái)先服務(wù)的原則進(jìn)行服務(wù)器的響應(yīng),這就需要使用Java多線程技術(shù)來(lái)實(shí)現(xiàn)這種服務(wù)器類(lèi)的設(shè)計(jì)工作。該線程的產(chǎn)生到消亡都是只為一個(gè)用戶(hù)提供服務(wù)。此外,Java多線程技術(shù)還應(yīng)該在網(wǎng)絡(luò)編程中建立客戶(hù)端類(lèi)的程序。所謂客戶(hù)端就是指由一些Java Apple小程序和Java程序組成的,它們的主要功能就是現(xiàn)用戶(hù)界面以及和服務(wù)器的通信控制。根據(jù)它們不同的功能進(jìn)行劃分的話(huà),我們可以把它們分為兩個(gè)相對(duì)獨(dú)立的部分,即主要管理圖形用戶(hù)界面的第一部分和實(shí)現(xiàn)和服務(wù)器的通信的第二部分,并建立客戶(hù)端線程類(lèi),進(jìn)而實(shí)現(xiàn)客戶(hù)端與該用戶(hù)有關(guān)的信息的發(fā)送與接收等。
因此,Java多線程技術(shù)的網(wǎng)絡(luò)應(yīng)用體系結(jié)構(gòu)主要表現(xiàn)為客戶(hù)/服務(wù)器模式,其中的服務(wù)器端主要負(fù)責(zé)數(shù)據(jù)和圖像等的存儲(chǔ)、維護(hù)、管理以及傳遞,客戶(hù)端則負(fù)責(zé)人機(jī)界面的操作、送出需求及顯示收回的數(shù)據(jù)。而網(wǎng)絡(luò)應(yīng)用體系結(jié)構(gòu)則分為Socket客戶(hù)和Socket服務(wù)器。其中,Socket客戶(hù)以Java Applet形式呈現(xiàn),Socket機(jī)制則是面向客戶(hù)/服務(wù)器模型設(shè)計(jì)的雙向鏈路的一端,其通常用來(lái)實(shí)現(xiàn)客戶(hù)端和服務(wù)器端的連接工作,它分為有聯(lián)接和無(wú)聯(lián)接兩種通訊方式,可以在不同的主機(jī)和進(jìn)程之間轉(zhuǎn)發(fā)進(jìn)行。應(yīng)該來(lái)說(shuō),服務(wù)器端Socket程序是網(wǎng)絡(luò)應(yīng)用程序的核心,而客戶(hù)端Socket應(yīng)用程序與服務(wù)器端Socket應(yīng)用程序在流程上很相似。當(dāng)我們?cè)谶M(jìn)行程序調(diào)試時(shí),應(yīng)該讓兩端的端口號(hào)設(shè)為一致,建立連接后要確定輸入和輸出流,并不同時(shí)使用一個(gè)端口。
3 結(jié)束語(yǔ)
綜上所述,多線程程序的編寫(xiě)本來(lái)是一件頗為復(fù)雜繁瑣且不太安全的事情。但是,自從出現(xiàn)了Java多線程技術(shù)之后,程序開(kāi)發(fā)人員就可以充分利用該技術(shù)來(lái)編寫(xiě)出更為安全、高效的多線程應(yīng)用程序,也使得多線程編寫(xiě)程序變得簡(jiǎn)單易行了。因此,我們利用Java多線程技術(shù)進(jìn)行網(wǎng)絡(luò)編程,是網(wǎng)絡(luò)上很多應(yīng)用程序得以實(shí)現(xiàn)的有效途徑,這也使得該技術(shù)得以在全世界范圍內(nèi)廣泛開(kāi)展與應(yīng)用起來(lái)。
參考文獻(xiàn):
[1]金勇華,曲俊生.Java網(wǎng)絡(luò)高級(jí)編程[M].北京:人民郵電出版社,2001.
[2]劉巍,唐學(xué)兵.利用Java的多線程技術(shù)實(shí)現(xiàn)數(shù)據(jù)庫(kù)的訪問(wèn)[J].計(jì)算機(jī)應(yīng)用,2002,22(12):121-123.
[3]張衛(wèi)民.Java語(yǔ)言及其應(yīng)用[M].北京:清華大學(xué)出版社,1996.
作者簡(jiǎn)介:阿不都艾尼・阿不都肉素力(1975-),男,維吾爾族,新疆烏魯木齊人,計(jì)算機(jī)應(yīng)用技術(shù)碩士,研究方向:軟件開(kāi)發(fā)、網(wǎng)絡(luò)編程。
作者單位:新疆職業(yè)大學(xué)信息技術(shù)學(xué)院,烏魯木齊 830001
點(diǎn)擊下頁(yè)還有更多>>>網(wǎng)絡(luò)編程技術(shù)論文