




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
《軟件體系結(jié)構(gòu)》實(shí)驗(yàn):軟件體系結(jié)構(gòu)風(fēng)格之應(yīng)用一、實(shí)驗(yàn)?zāi)康耐ㄟ^KWIC實(shí)例分析,理解和掌握軟件體系結(jié)構(gòu)風(fēng)格設(shè)計(jì)與實(shí)現(xiàn)。二、實(shí)驗(yàn)內(nèi)容多種軟件風(fēng)格設(shè)計(jì)與實(shí)現(xiàn)之KWIC實(shí)例:1.采用主/子程序體系結(jié)構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)2.采用面向?qū)ο篌w系架構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)3.采用管道過濾體系架構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)4.采用事件過程調(diào)用體系架構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)三、實(shí)驗(yàn)要求與實(shí)驗(yàn)環(huán)境熟練掌握基于主/子程序體系結(jié)構(gòu)風(fēng)格的KWIC關(guān)鍵詞索引系統(tǒng),在此基礎(chǔ)上,完成基于面向?qū)ο篌w系架構(gòu)風(fēng)格的KWIC關(guān)鍵詞索引系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)。選做基于管道過濾體系架構(gòu)風(fēng)格的KWIC關(guān)鍵詞索引系統(tǒng);選做基于事件過程調(diào)用體系架構(gòu)風(fēng)格的KWIC關(guān)鍵詞索引系統(tǒng)。實(shí)驗(yàn)課前完成實(shí)驗(yàn)報(bào)告的實(shí)驗(yàn)?zāi)康?、?shí)驗(yàn)環(huán)境、實(shí)驗(yàn)內(nèi)容、實(shí)驗(yàn)操作過程等內(nèi)容;實(shí)驗(yàn)課中獨(dú)立/團(tuán)隊(duì)操作完成實(shí)驗(yàn)報(bào)告的實(shí)驗(yàn)操作、實(shí)驗(yàn)結(jié)果及結(jié)論等內(nèi)容;每人一臺(tái)PC機(jī),所需軟件Win2003/XP、UML工具(EclipseUML/Rose/Visio/StartUML/)、Eclipse/MyEclipse、JDK6.0等。四、實(shí)驗(yàn)操作1、采用主/子程序體系結(jié)構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)主程序/子程序風(fēng)格(MainProgram/SubroutineStyle)將系統(tǒng)組織成層次結(jié)構(gòu),包括一個(gè)主程序和一系列子程序。主程序是系統(tǒng)的控制器,負(fù)責(zé)調(diào)度各子程序的執(zhí)行。各子程序又是一個(gè)局部的控制器,調(diào)度其子程序的執(zhí)行。設(shè)計(jì)詞匯表:主程序main(),子程序shift(),sort()方法,方法的調(diào)用,返回構(gòu)件和連接件類型:構(gòu)件:各類子程序,如shift(),sort()連接件:方法的調(diào)用基本的計(jì)算模型:子程序有shift(),sort()方法,shift()對(duì)單詞進(jìn)行移位,sort()方法對(duì)單詞進(jìn)行排序風(fēng)格的基本不變性:主程序有順序地調(diào)用子程序,單線程控制。KWIC的主/子程序體系結(jié)構(gòu)風(fēng)格示意圖如下所示:子程序風(fēng)格的重要設(shè)計(jì)決策與約束有:/主程序使用(程序調(diào)用)關(guān)系建立連接件,以層次分解的方式建立系-基于聲明●統(tǒng)部件,共同組成層次結(jié)構(gòu)。每一個(gè)上層部件可以“使用”下層部件,但下層部件不能“使用”上層部●件,即不允許逆方向調(diào)用。●系統(tǒng)應(yīng)該是單線程執(zhí)行。主程序部件擁有最初的執(zhí)行控制權(quán),并在“使用”中將控制權(quán)轉(zhuǎn)移給下層子程序?!褡映绦蛑荒軌蛲ㄟ^上層轉(zhuǎn)移來獲得控制權(quán),可以在執(zhí)行中將控制權(quán)轉(zhuǎn)交給下層的子子程序,并在自身執(zhí)行完成之后必須將控制權(quán)還交給上層部件。KWIC主程序/子程序風(fēng)格的Java語言實(shí)現(xiàn)見附件。主程序/子程序風(fēng)格的主要實(shí)現(xiàn)機(jī)制是模塊實(shí)現(xiàn),它將每個(gè)子程序都實(shí)現(xiàn)為一個(gè)模塊,主程序?qū)崿F(xiàn)為整個(gè)系統(tǒng)的起始模塊。依照抽象規(guī)格的層次關(guān)系,實(shí)現(xiàn)模塊也被組織為相應(yīng)的層次機(jī)構(gòu),通過導(dǎo)入/導(dǎo)出關(guān)系相連接。需要強(qiáng)調(diào)的是,雖然主程序/子程序風(fēng)格非常類似于結(jié)構(gòu)化程序的結(jié)構(gòu),但是主程序/子程序風(fēng)格是基于部件與連接件建立的高層結(jié)構(gòu)。它的部件不同于程序,而是更加粗粒度的模塊。而且,在部件的實(shí)現(xiàn)模塊內(nèi)部,可以使用結(jié)構(gòu)化方法,也可以使用面向?qū)ο蠓椒?,這并不妨礙整個(gè)系統(tǒng)的高層結(jié)構(gòu)符合主程序/子程序風(fēng)格的約定。主程序/子程序風(fēng)格的優(yōu)點(diǎn)有:流程清晰,易于理解。強(qiáng)控制性。嚴(yán)格的層次分解和嚴(yán)格的控制權(quán)轉(zhuǎn)移使得主程序/子程序風(fēng)格對(duì)程序的實(shí)際執(zhí)行過程具備很強(qiáng)的控制能力,這帶來了一個(gè)特點(diǎn):如果一個(gè)子程序所連接的子子程序是正確的,那么就很容易保證該子程序的“正確性”。所以,主程序/子程序風(fēng)格比其他常見風(fēng)格更能控制程序的“正確性”。2、采用面向?qū)ο篌w系結(jié)構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)面向?qū)ο笫斤L(fēng)格,需要強(qiáng)調(diào)說明的是它的“對(duì)象”是部件,屬于高層結(jié)構(gòu)的元素,雖然名稱相同,但它并不是面向?qū)ο蠓椒ㄖ兴龅摹皩?duì)象”實(shí)體。“面向?qū)ο笫健憋L(fēng)格的命名是因?yàn)樗梃b了面向?qū)ο蠓椒ǖ乃枷耄皇且驗(yàn)樗褂妹嫦驅(qū)ο蠓椒▽?shí)現(xiàn)體系結(jié)構(gòu),這也是在該風(fēng)格名稱中有一個(gè)“式”字的原因。面向?qū)ο笫斤L(fēng)格的主要實(shí)現(xiàn)機(jī)制是模塊實(shí)現(xiàn),它將每個(gè)對(duì)象部件實(shí)例都實(shí)現(xiàn)為一個(gè)模塊。存在連接的對(duì)象部件實(shí)例之間會(huì)存在模塊的導(dǎo)入/導(dǎo)出關(guān)系。每個(gè)模塊內(nèi)部可以是基于面向?qū)ο蠓椒ǖ膶?shí)現(xiàn),也可以是基于結(jié)構(gòu)化方法的實(shí)現(xiàn)。設(shè)計(jì)詞匯表:(1)input,output,shift,sort,main類(2)shift,sort,output對(duì)象(3)對(duì)象間的消息傳遞構(gòu)件和連接件類型:(1)構(gòu)件類型:對(duì)象(2)連接件的類型:為對(duì)象間的消息傳遞KWIC的面向?qū)ο蟪绦蝮w系結(jié)構(gòu)風(fēng)格示意圖如下所示:基本的計(jì)算模型:模塊從文本文件input.txt中一行一行讀取單InputSortShift模塊用于將單詞移位。模塊將單詞進(jìn)行排序。output.txtOutput模塊將最終結(jié)果寫到文本文件中KWIC面向?qū)ο箫L(fēng)格的Java語言實(shí)現(xiàn)見附件。面向?qū)ο笫斤L(fēng)格的優(yōu)點(diǎn)有:內(nèi)部實(shí)現(xiàn)的可修改性。因?yàn)槊嫦驅(qū)ο笫斤L(fēng)格要求封裝內(nèi)部數(shù)據(jù),隱藏內(nèi)部實(shí)現(xiàn),所以它可以在不影響外界的情況下,變更其內(nèi)部實(shí)現(xiàn)。易開發(fā)、易理解、易復(fù)用的結(jié)構(gòu)組織。面向?qū)ο笫斤L(fēng)格將系統(tǒng)組織為一系列平等、自治的單位,每個(gè)單位負(fù)責(zé)自身的“正確性”,不同單位之間僅僅是通過方法調(diào)用相連接,這非常契合模塊化思想,能夠建立一個(gè)易開發(fā)、易理解、易復(fù)用的實(shí)現(xiàn)結(jié)構(gòu)。3、采用管道和過濾器體系結(jié)構(gòu)風(fēng)格實(shí)現(xiàn)KWIC關(guān)鍵詞索引系統(tǒng)管道-過濾器風(fēng)格將系統(tǒng)的功能邏輯建立為部件集合。每個(gè)部件實(shí)例完成一個(gè)對(duì)數(shù)據(jù)流的獨(dú)立功能處理,它接收數(shù)據(jù)流輸入,進(jìn)行轉(zhuǎn)換和增量后進(jìn)行數(shù)據(jù)流輸出。連接件是管道機(jī)制,它將前一個(gè)過濾器的數(shù)據(jù)流輸出傳遞給后一個(gè)過濾器作為數(shù)據(jù)流輸入。連接件也可能會(huì)進(jìn)行數(shù)據(jù)流的功能處理,進(jìn)行轉(zhuǎn)換或增量,但連接件進(jìn)行功能處理的目的為了適配前一個(gè)過濾器的輸出和后一個(gè)過濾器的輸入,而不是為了直接承載軟件系統(tǒng)的需求。各個(gè)過濾器可以并發(fā)執(zhí)行。每個(gè)過濾器都可以在數(shù)據(jù)輸入不完備的情況下就開始進(jìn)行處理,每次接到一部分?jǐn)?shù)據(jù)流輸入就處理和產(chǎn)生一部分輸出。這樣,整個(gè)的過濾器網(wǎng)絡(luò)就形成了一條流水線。設(shè)計(jì)詞匯表:Pipe,FilterFilter構(gòu)件和連接件類型構(gòu)件:Pipe連接件:的管道過濾器體系結(jié)構(gòu)風(fēng)格示意圖如下所示:KWICInputShiftinginputmediumsortingoutputFilterPipeSystemI/O基本的計(jì)算模型:過濾器讀管道輸出流,過濾器寫管道輸入流,過濾器通過對(duì)輸入流的增量計(jì)算來完成風(fēng)格的基本不變性:過濾器是獨(dú)立的實(shí)體,它們之間通過管道傳遞數(shù)據(jù)過濾器風(fēng)格可以為所有過濾器部件實(shí)例建立模塊實(shí)現(xiàn),每個(gè)過濾器部件-管道現(xiàn)為一個(gè)單獨(dú)的模塊,可以為所有簡單的管道連接件建立一個(gè)通用的模實(shí)例被實(shí)塊實(shí)現(xiàn),為每個(gè)復(fù)雜的管道連接件建立一個(gè)單獨(dú)的模塊實(shí)現(xiàn),相關(guān)聯(lián)過濾器部件的實(shí)現(xiàn)模塊要導(dǎo)入管道實(shí)現(xiàn)模塊。過濾器風(fēng)格需要為所有過濾器-因?yàn)楣艿?過濾器風(fēng)格需要并發(fā)執(zhí)行,所以管道部件實(shí)例和復(fù)雜連接件實(shí)例建立進(jìn)程實(shí)現(xiàn),每個(gè)過濾器部件實(shí)例和復(fù)雜連接件實(shí)例被實(shí)現(xiàn)為一個(gè)進(jìn)程。如果操作系統(tǒng)能夠提供管道機(jī)制,那么進(jìn)程實(shí)現(xiàn)時(shí)的簡單管道可以利用操作系統(tǒng)提供的機(jī)制來實(shí)現(xiàn)。此時(shí),所有的實(shí)現(xiàn)進(jìn)程都需要部署在同一個(gè)物理節(jié)點(diǎn)。如果有中間件平臺(tái)能夠提供管道機(jī)制,那么進(jìn)程實(shí)現(xiàn)時(shí)的簡單管道可以利用中間件平臺(tái)提供的機(jī)制來實(shí)現(xiàn)。此時(shí),各個(gè)實(shí)現(xiàn)進(jìn)程可以被部署在不同的網(wǎng)絡(luò)節(jié)點(diǎn)。KWIC基于管道過濾器風(fēng)格的JAVA語言實(shí)現(xiàn)見附件。實(shí)驗(yàn)結(jié)果:輸入文件:輸出文件:五、實(shí)驗(yàn)總結(jié)通過本次實(shí)驗(yàn)認(rèn)識(shí)到軟件體系結(jié)構(gòu)風(fēng)格是描述某一特定應(yīng)用領(lǐng)域中系統(tǒng)組織方式的慣用模式。軟件體系結(jié)構(gòu)設(shè)計(jì)的一個(gè)核心問題是能否使用重復(fù)的體系結(jié)構(gòu)模式,即能達(dá)到體系結(jié)構(gòu)級(jí)的軟件重用。也就是說,能否在不同的軟件系統(tǒng)中,使用同一體系結(jié)構(gòu)。子程序體系結(jié)構(gòu)風(fēng)格、面向?qū)ο篌w系架構(gòu)風(fēng)格、管道過濾體系架構(gòu)風(fēng)格、主/用事件過程調(diào)用體系架構(gòu)風(fēng)格是四種常用的軟件體系結(jié)構(gòu)風(fēng)格,對(duì)于實(shí)現(xiàn)同一種功能的軟件可以分別采用以上的這四種風(fēng)格。在建立體系結(jié)構(gòu)過程中,不斷明確設(shè)計(jì)詞匯表、構(gòu)建和連接件的類型、可容許的結(jié)構(gòu)模式、基本的計(jì)算類型、風(fēng)格的基本不變形、常用例子、優(yōu)缺點(diǎn)。通過明確這些問題,可以理解一種體系結(jié)構(gòu)的基本特征,從而為實(shí)現(xiàn)體系結(jié)構(gòu)重用提供可能。進(jìn)行建模和實(shí)現(xiàn),讓我動(dòng)手把簡單的軟件體系結(jié)構(gòu)代碼實(shí)現(xiàn),通過對(duì)KWIC在程序里體現(xiàn)體系結(jié)構(gòu)的基本思想,拓展了數(shù)據(jù)結(jié)構(gòu)的基本知識(shí),將軟件設(shè)計(jì)思想體現(xiàn)在編碼環(huán)節(jié),為以后的體系結(jié)構(gòu)設(shè)計(jì)提供基礎(chǔ)。KWIC主程序/子程序風(fēng)格的Java語言實(shí)現(xiàn):publicstaticvoidalphabetize(){String[]tmpArray=newString[shiftedLineIndexes.size()];shiftedLineIndexes.toArray(tmpArray);Arrays.sort(tmpArray);sortedLineIndexes=tmpArray;}publicstaticvoidOutput(StringoutputAddress){FileWriterfw=null;try{fw=newFileWriter(outputAddress);}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}BufferedWriterbw=newBufferedWriter(fw);for(inti=0;i<sortedLineIndexes.length;i++){try{bw.write(sortedLineIndexes[i]);bw.newLine();}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}}try{bw.close();}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}}publicstaticvoidInput(StringiFile){FileReaderfr=null;try{fr=newFileReader(iFile);}catch(FileNotFoundExceptione){e.printStackTrace();}BufferedReaderbr=newBufferedReader(fr);textLines=newArrayList<String>();try{while(br.ready()){textLines.add(br.readLine());}}catch(IOExceptione){e.printStackTrace();}}publicstaticvoidCircularShift(){shiftedLineIndexes=newArrayList<String>();for(inti=0;i<textLines.size();i++){StringorinLine=textLines.get(i);Stringsarray[]=orinLine.split(?);for(intj=0;j<sarray.length;j++){StringnewLine=sarray[j];if(sarray.length>1){if(j==sarray.length-1){k=0;k<(sarray.length-1);k++){int(fornewLine=newLine+?+sarray[k];}}else{for(intk=j+1;k<sarray.length;k++){newLine=newLine+?+sarray[k];}for(intm=0;m<j;m++){newLine=newLine++sarray[m];}}}shiftedLineIndexes.add(newLine);}}}KWIC面向?qū)ο箫L(fēng)格的Java語言實(shí)現(xiàn)://InputStore.javaimportjava.io.BufferedReader;importjava.io.FileNotFoundException;importjava.io.FileReader;importjava.io.IOException;importjava.util.ArrayList;publicclassInputStore{publicArrayList<String>ls;publicInputStore(ArrayList<String>ls){this.ls=ls;}publicvoidinput(StringinputFile){FileReaderfr=null;try{fr=newFileReader(inputFile);}catch(FileNotFoundExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}BufferedReaderbr=newBufferedReader(fr);try{while(br.ready()){ls.add(br.readLine());}}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}}}//Output.javaimportjava.io.BufferedWriter;importjava.io.FileWriter;importjava.io.IOException;importjava.util.ArrayList;publicclassOutput{publicArrayList<String>ls;publicOutput(ArrayList<String>ls){this.ls=ls;}publicvoidoutput(StringoutputAddress){FileWriterfw=null;try{fw=newFileWriter(outputAddress);}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}BufferedWriterbw=newBufferedWriter(fw);for(inti=0;i<ls.size();i++){try{bw.write(ls.get(i));bw.newLine();}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}}try{bw.close();}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}}}//Alphabetizer.javaimportjava.util.ArrayList;importjava.util.Arrays;publicclassAlphabetizer{publicArrayList<String>ls;publicAlphabetizer(ArrayList<String>ls){this.ls=ls;}publicvoidalpha(){String[]tmpArray=newString[ls.size()];ls.toArray(tmpArray);Arrays.sort(tmpArray);for(inti=0;i<ls.size();i++){ls.set(i,tmpArray[i]);}}}//CircularShifter.javaimportjava.util.ArrayList;publicclassCircularShifter{publicArrayList<String>ls;publicCircularShifter(ArrayList<String>ls){this.ls=ls;}publicvoidshift(){ArrayList<String>shiftedLineIndexes=newArrayList<String>();for(inti=0;i<ls.size();i++){StringorinLine=ls.get(i);Stringsarray[]=orinLine.split();for(intj=0;j<sarray.length;j++){StringnewLine=sarray[j];if(sarray.length>1){if(j==sarray.length-1){for(intk=0;k<(sarray.length-1);k++){newLine=newLine++sarray[k];}}else{for(intk=j+1;k<sarray.length;k++){newLine=newLine++sarray[k];}for(intm=0;m<j;m++){newLine=newLine++sarray[m];}}}shiftedLineIndexes.add(newLine);}}ls=shiftedLineIndexes;}}//Main.javaimportjava.util.ArrayList;publicclassMain{publicstaticvoidmain(String[]args){//TODOAuto-generatedmethodstubArrayList<String>ls=newArrayList<String>();InputStoreinputStore=newInputStore(ls);inputStore.input(input.txt);CircularShiftercs=newCircularShifter(ls);cs.shift();Alphabetizeralp=newAlphabetizer(cs.ls);alp.alpha();Outputoutput=newOutput(alp.ls);output.output(output.txt);}}KWIC基于管道過濾器風(fēng)格的JAVA語言實(shí)現(xiàn)//Main類packagekwic_pipe;importjava.io.File;importjava.util.Scanner;publicclassMain{publicstaticvoidmain(String[]args){Fileinfile=newFile(e:\\mykwic_in.txt);Fileoutfile=newFile(e:\\mykwic_out.txt);Scannerinputfile;Scanneroutputfile;try{inputfile=newScanner(infile);outputfile=newScanner(outfile);//定義三個(gè)管道Pipepipe1=newPipe();Pipepipe2=newPipe();Pipepipe3=newPipe();//定義四種過濾器Inputinput=newInput(infile,pipe1);Shiftshift=newShift(pipe1,pipe2);Outputoutput=newOutput(pipe3,outfile);//啟動(dòng)四種過濾器的線程input.transform()shift.transform();output.transform();//直接輸出結(jié)果System.out.println(-----infile-----);Stringstr=null;while(inputfile.hasNextLine()){str=inputfile.nextLine();System.out.println(str);}System.out.println(inputend);Thread.sleep(3000);System.out.println(-----outfile-----);while(outputfile.hasNextLine()){System.out.println(str);}inputfile.close();outputfile.close();}catch(Exceptione){e.getMessage();}}}//Filter類packagekwic_pipe;importjava.io.IOException;publicabstractclassFilter{//定義輸入管道protectedPipeinput;//定義輸出管道protectedPipeoutput;privatebooleanisStart=false;Filter(Pipeinput,Pipeoutput){this.input=input;this.output=output;}//防止多次調(diào)用,調(diào)用之后線程開始執(zhí)行publicvoidstart(){if(!isStart){isStart=true;Threadthread=newThread();thread.start();}}//線程的run方法publicvoidrun(){try{this.transform();}catch(IOExceptione){e.getMessage();}}//將輸入數(shù)據(jù)轉(zhuǎn)換為所需數(shù)據(jù)并寫入輸出管道//由子類實(shí)現(xiàn)抽象方法protectedabstractvoidtransform()throwsIOException;}Pipe類packagekwic_pipe;importjava.io.IOException;importjava.io.PipedReader;importjava.io.PipedWriter;importjava.io.PrintWriter;importjava.util.Scanner;publicclassPipe{//輸入管道privateScannerpipereader;//輸出管道privatePrintWriterpipewriter;publicPipe(){PipedWriterpw=newPipedWriter();PipedReaderpr=newPipedReader();try{pw.connect(pr);}catch(IOExceptione){e.getMessage();}pipewriter=newPrintWriter(pw);pipereader=newScanner(pr);}//讀入一行數(shù)據(jù)到管道//@return讀入的數(shù)據(jù)publicStringreaderLine()throwsIOException{returnpipereader.nextLine();}//從管道輸出一行數(shù)據(jù)publicvoidwriterLine(Stringstrline)throwsIOException{pipewriter.println(strline);}//將讀管道關(guān)閉,調(diào)用該方法后,不能再從管道中讀數(shù)據(jù)//如不能關(guān)閉則拋出異publicvoidcloseReader()throwsIOException{pipereader.close();}//先刷新數(shù)據(jù),在將寫管道關(guān)閉,調(diào)用該方法后,不能向管道中寫數(shù)據(jù)//如不能關(guān)閉則拋出異常publicvoidcloseWriter()throwsIOException{pipewriter.flush();pipewriter.close();}}Alphabetizer類packagekwic_pipe;importjava.io.IOException;importjava.util.ArrayList;importjava.util.Collections;publicclassAlphabetizerextendsFilter{privateArrayList<String>al=newArrayList<String>();Alphabetizer(Pipeinput,Pipeoutput){super(input,output);}//對(duì)讀入的數(shù)據(jù)進(jìn)行排序protectedvoidtransform()throwsIOException{Stringtempline=null;//讀入數(shù)據(jù)while((templine=input.readerLine())!=null){al.add(templine);}//按字母表排序Collections.sort(al);//對(duì)排序后的數(shù)據(jù)進(jìn)行輸出for(inti=0;i<al.size();i++){output.writerLine(al.get(i));}input.closeReader();output.closeWriter();}}Shift類packagekwic_pipe;importjava.io.IOException;importjava.util.ArrayList;publicclassShiftextendsFilter{//單詞的列表privateArrayList<String>wordlist=newArrayList<String>();重組后的行的列表//privateArrayList<String>linelist=newArrayList<String>();Shift(Pipeinput,Pipeoutput){super(input,output);}@Overrideprotectedvoidtransform()throwsIOException{Stringtempline=\;//讀數(shù)據(jù)while((templine=input.readerLine())!=null){//將數(shù)據(jù)拆分為不同單詞this.lineSplitWord(templine);//將單詞重組為句子this.recombination();//輸出重組結(jié)果for(inti=0;i<linelist.size();i++){output.writerLine(linelist.get(i));}//清空wordlist、linelist和templinewordlist.clear();linelist.clear();templine=\;}input.closeReader();output.closeWriter();}//從一行中提取單詞存入單詞表中privatevoidlineSplitWord(Stringline){Stringword=\;inti=0;while(i<line.length()){if(line.charAt(i)!=''){word+=line.charAt(i);}else{wordlist.add(word);}i++;}}privatevoidrecombination(){for(intj=0;j<wordlist.size();j++){Stringtempline=\;for
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度技術(shù)合作項(xiàng)目終止及解除合同書
- 2025年度農(nóng)村水井承包合同與農(nóng)業(yè)灌溉用水權(quán)流轉(zhuǎn)及監(jiān)管協(xié)議
- 2025年度特殊年齡段勞動(dòng)者用工協(xié)議及權(quán)益保障
- 2025年度個(gè)體商戶勞動(dòng)合同(家政服務(wù)行業(yè)合作)
- 5G通信借款居間合同模板
- 2025年度分紅股收益確認(rèn)與分配協(xié)議
- 2025年度影視作品著作權(quán)許可及廣告植入合作合同
- 2025年度分手協(xié)議書模板:分手后共同債務(wù)承擔(dān)協(xié)議
- 2025年度房屋拆除與建筑垃圾清運(yùn)一體化服務(wù)合同
- 2025年度企業(yè)導(dǎo)師帶徒技能傳承服務(wù)協(xié)議
- 2025年湖南現(xiàn)代物流職業(yè)技術(shù)學(xué)院高職單招職業(yè)技能測試近5年??及鎱⒖碱}庫含答案解析
- 第二十章手術(shù)減肥及體形塑造美容手術(shù)美容外科學(xué)概論講解
- 2025年蘇州衛(wèi)生職業(yè)技術(shù)學(xué)院高職單招職業(yè)技能測試近5年??及鎱⒖碱}庫含答案解析
- 履帶式剪叉高空作業(yè)平臺(tái)安全操作規(guī)程
- 《水稻育秧技術(shù)新》課件
- 2024-2025年第一學(xué)期初中德育工作總結(jié)
- 圍手術(shù)期手術(shù)患者護(hù)理要點(diǎn)
- 2025年大連長興開發(fā)建設(shè)限公司工作人員公開招聘高頻重點(diǎn)提升(共500題)附帶答案詳解
- 貨物學(xué) 課件1.3貨物的計(jì)量
- 《鈉離子電池用電解液編制說明》
- 全球醫(yī)療旅游經(jīng)濟(jì)的現(xiàn)狀與未來趨勢
評(píng)論
0/150
提交評(píng)論