版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第一單元:計(jì)算機(jī)與計(jì)算機(jī)科學(xué)課文A:計(jì)算機(jī)概覽一、引言計(jì)算機(jī)是一種電子設(shè)備,它能接收一套指令或一個(gè)程序,然后通過(guò)對(duì)數(shù)字?jǐn)?shù)據(jù)進(jìn)行運(yùn)算或?qū)ζ渌问降男畔⑦M(jìn)行處理來(lái)執(zhí)行該程序。要不是由于計(jì)算機(jī)的發(fā)展,現(xiàn)代的高科技世界是不可能產(chǎn)生的。不同類(lèi)型和大小的計(jì)算機(jī)在整個(gè)社會(huì)被用于存儲(chǔ)和處理各種數(shù)據(jù),從保密政府文件、銀行交易到私人家庭賬目。計(jì)算機(jī)通過(guò)自動(dòng)化技術(shù)開(kāi)辟了制造業(yè)的新紀(jì)元,而且它們也增強(qiáng)了現(xiàn)代通信系統(tǒng)的性能。在幾乎每一個(gè)研究和應(yīng)用技術(shù)領(lǐng)域,從構(gòu)建宇宙模型到產(chǎn)生明天的氣象報(bào)告,計(jì)算機(jī)都是必要的工具,并且它們的應(yīng)用本身就開(kāi)辟了人們推測(cè)的新領(lǐng)域。數(shù)據(jù)庫(kù)服務(wù)和計(jì)算機(jī)網(wǎng)絡(luò)使各種各樣的信息源可供使用。同樣的先進(jìn)技術(shù)
2、也使侵犯?jìng)€(gè)人隱私和商業(yè)秘密成為可能。計(jì)算機(jī)犯罪已經(jīng)成為作為現(xiàn)代技術(shù)代價(jià)組成部分的許多風(fēng)險(xiǎn)之一。二、歷史第一臺(tái)加法機(jī)是法國(guó)科學(xué)家、數(shù)學(xué)家和哲學(xué)家布萊斯.帕斯卡于1642年設(shè)計(jì)的,它是數(shù)字計(jì)算機(jī)的先驅(qū)。這個(gè)裝置使用了一系列帶有10個(gè)齒的輪子,每個(gè)齒代表從0到9的一個(gè)數(shù)字。輪子互相連接,從而通過(guò)按照正確的齒數(shù)向前轉(zhuǎn)動(dòng)輪子,就可以將數(shù)字彼此相加。17世紀(jì)70年代,德國(guó)哲學(xué)家和數(shù)學(xué)家戈特弗里德.威廉.萊布尼茲對(duì)這臺(tái)機(jī)器進(jìn)行了改良,設(shè)計(jì)了一臺(tái)也能做乘法的機(jī)器。法國(guó)發(fā)明家約瑟夫瑪麗.雅卡爾,在設(shè)計(jì)自動(dòng)織機(jī)時(shí),使用了穿孔的薄木板來(lái)控制復(fù)雜圖案的編織。在19世紀(jì)80年代期間,美國(guó)統(tǒng)計(jì)學(xué)家赫爾曼.何勒里斯,想出了
3、使用類(lèi)似雅卡爾的木板那樣的穿孔卡片來(lái)處理數(shù)據(jù)的主意。通過(guò)使用一種將穿孔卡片從電觸點(diǎn)上移過(guò)的系統(tǒng),他得以為1890年的美國(guó)人口普查匯編統(tǒng)計(jì)信息。1、分析機(jī)也是在19世紀(jì),英國(guó)數(shù)學(xué)家和發(fā)明家查爾斯.巴比奇,提出了現(xiàn)代數(shù)字計(jì)算機(jī)的原理。他構(gòu)想出旨在處理復(fù)雜數(shù)學(xué)題的若干機(jī)器,如差分機(jī)。許多歷史學(xué)家認(rèn)為,巴比奇及其合伙人,數(shù)學(xué)家?jiàn)W古斯塔.埃達(dá).拜倫,是現(xiàn)代數(shù)字計(jì)算機(jī)的真正先驅(qū)。巴比奇的設(shè)計(jì)之一,分析機(jī),具有現(xiàn)代計(jì)算機(jī)的許多特征。它有一個(gè)以一疊穿孔卡片的形式存在的輸入流、一個(gè)保存數(shù)據(jù)的“倉(cāng)庫(kù)”、一個(gè)進(jìn)行算術(shù)運(yùn)算的“工廠”和一個(gè)產(chǎn)生永久性紀(jì)錄的打印機(jī)。巴比奇未能將這個(gè)想法付諸實(shí)踐,盡管在那個(gè)時(shí)代它在技術(shù)上很
4、可能是可行的。2、早期的計(jì)算機(jī)模擬計(jì)算機(jī)是19世紀(jì)末開(kāi)始制造的。早期型號(hào)是靠轉(zhuǎn)動(dòng)的軸和齒輪來(lái)進(jìn)行計(jì)算的。用任何其他方法都難以計(jì)算的方程近似數(shù)值,可以用這樣的機(jī)器來(lái)求得。開(kāi)爾文勛爵制造了一臺(tái)機(jī)械潮汐預(yù)報(bào)器,這實(shí)際上就是一臺(tái)專(zhuān)用模擬計(jì)算機(jī)。第一次和第二次世界大戰(zhàn)期間,機(jī)械模擬計(jì)算系統(tǒng),以及后來(lái)的電動(dòng)模擬計(jì)算系統(tǒng),在潛艇上被用作魚(yú)雷航線預(yù)測(cè)器,在飛機(jī)上被用作轟炸瞄準(zhǔn)具的控制器。有人還設(shè)計(jì)了另一個(gè)系統(tǒng),用于預(yù)測(cè)密西西比河流域春天的洪水。3、電子計(jì)算機(jī)第二次世界大戰(zhàn)期間,以倫敦北面的布萊切利公園為工作地點(diǎn)的一組科學(xué)家和數(shù)學(xué)家,制造了最早的全電子數(shù)字計(jì)算機(jī)之一:“巨人”。到1943年12月,這個(gè)包含了15
5、00個(gè)真空管的“巨人”開(kāi)始運(yùn)轉(zhuǎn)了。它被以艾倫.圖靈為首的小組用于破譯德國(guó)用恩尼格碼加密的無(wú)線電報(bào),他們的嘗試大部分是成功的。除此而外,在美國(guó),約翰.阿塔納索夫和克利福德.貝里早在1939年就在艾奧瓦州立學(xué)院制造了一臺(tái)原型電子機(jī)。這臺(tái)原型機(jī)和后來(lái)的研究工作都是悄悄完成的,而且后來(lái)因1945年電子數(shù)字積分計(jì)算機(jī)(ENIAC)的研制而顯得相形見(jiàn)絀。ENIAC被授予了專(zhuān)利。但是,數(shù)十年后,在1973年,當(dāng)該機(jī)被揭露吸收了在阿塔納索夫貝里計(jì)算機(jī)中首次使用的原理后,這項(xiàng)專(zhuān)利被廢除了。圖1 A - 1:E N IAC是最早的全電子數(shù)字計(jì)算機(jī)之一。ENIAC(見(jiàn)圖1A-1)含有18,000個(gè)真空管,具有每分鐘
6、幾百次的乘法運(yùn)算速度,但是,其程序最初是通過(guò)導(dǎo)線傳送到處理器內(nèi)的,必須由人工更改。根據(jù)美籍匈牙利數(shù)學(xué)家約翰.馮.諾伊曼的想法,后來(lái)制造的機(jī)器帶有一個(gè)程序存儲(chǔ)器。指令像數(shù)據(jù)一樣存儲(chǔ)在“存儲(chǔ)器”中,使計(jì)算機(jī)在執(zhí)行過(guò)程中擺脫了紙帶閱讀器的速度限制,并使問(wèn)題在不給計(jì)算機(jī)重新接線的情況下得以解決。20世紀(jì)50年代末,晶體管在計(jì)算機(jī)中的應(yīng)用,標(biāo)志著比在真空管機(jī)器情況下體積小、速度快、用途廣的邏輯元件的出現(xiàn)。由于晶體管使用的功率小得多,壽命也長(zhǎng)得多,僅這項(xiàng)發(fā)展本身就導(dǎo)致了被稱(chēng)之為第二代計(jì)算機(jī)的改良機(jī)器的產(chǎn)生。元件變小了,元件的間距也變小了,而且系統(tǒng)的制造成本也變得低得多。4、集成電路20世紀(jì)60年代末,集成
7、電路(見(jiàn)圖1A-2)得到采用,從而有可能將許多晶體管制作在一塊硅襯底上,晶體管之間用覆鍍?cè)谶m當(dāng)位置的導(dǎo)線相連接。集成電路導(dǎo)致價(jià)格、尺寸和故障率的進(jìn)一步降低。20世紀(jì)70年代中期,隨著大規(guī)模集成電路和后來(lái)的超大規(guī)模集成電路(微芯片)的采用,成千上萬(wàn)個(gè)彼此相連的晶體管被蝕刻在一塊硅襯底上,于是微處理器成為現(xiàn)實(shí)。圖1 A - 2:集成電路那么,再回過(guò)頭來(lái)看看現(xiàn)代計(jì)算機(jī)處理開(kāi)關(guān)值的能力:20世紀(jì)70年代的計(jì)算機(jī)一般一次能夠處理8個(gè)開(kāi)關(guān)值。也就是說(shuō),在每個(gè)循環(huán)中,它們能處理8個(gè)二進(jìn)制數(shù)字或位的數(shù)據(jù)。8個(gè)位為一組,稱(chēng)為一個(gè)字節(jié);每個(gè)字節(jié)包含256個(gè)開(kāi)與關(guān)(或0與1)的可能模式。每個(gè)模式相當(dāng)于一條指令、一條
8、指令的一部分或者一個(gè)特定的數(shù)據(jù)類(lèi)型,如一個(gè)數(shù)字、一個(gè)字符或一個(gè)圖形符號(hào)。例如,11010010這個(gè)模式可能是二進(jìn)制數(shù)據(jù)在此情況下代表210這個(gè)十進(jìn)制數(shù)字,或者它可能是一條指令,告訴計(jì)算機(jī)將存儲(chǔ)在其交換設(shè)備中的數(shù)據(jù)與存儲(chǔ)在存儲(chǔ)芯片某個(gè)位置的數(shù)據(jù)進(jìn)行比較。一次能處理16、32和64位數(shù)據(jù)的處理器的研制,提高了計(jì)算機(jī)的速度。一臺(tái)計(jì)算機(jī)能夠處理的全部可識(shí)別模式操作總清單稱(chēng)為其指令集。隨著現(xiàn)代數(shù)字計(jì)算機(jī)的不斷發(fā)展,這兩個(gè)因素能夠同時(shí)處理的位數(shù)和指令集的大小在繼續(xù)增長(zhǎng)。三、硬件不論尺寸大小,現(xiàn)代數(shù)字計(jì)算機(jī)在概念上都是類(lèi)似的。然而,根據(jù)成本與性能,它們可分為幾類(lèi):個(gè)人計(jì)算機(jī)或微型計(jì)算機(jī),一種成本較低的機(jī)器,
9、通常只有桌面大?。ūM管“膝上型計(jì)算機(jī)”小到能夠放入公文包,而“掌上型計(jì)算機(jī)”能夠放入口袋);工作站,一種具有增強(qiáng)型圖形與通信能力、從而使其對(duì)于辦公室工作特別有用的微型計(jì)算機(jī);小型計(jì)算機(jī),一般就個(gè)人使用而言太昂貴,其性能適合于工商企業(yè)、學(xué)?;?qū)嶒?yàn)室;以及大型機(jī),一種大型的昂貴機(jī)器,具有滿足大規(guī)模工商企業(yè)、政府部門(mén)、科研機(jī)構(gòu)或者諸如此類(lèi)機(jī)構(gòu)需要的能力(其中體積最大、速度最快的稱(chēng)為巨型計(jì)算機(jī))。一臺(tái)數(shù)字計(jì)算機(jī)不是單一的機(jī)器。確切地說(shuō),它是由5個(gè)不同的要素組成的系統(tǒng):(1)中央處理器;(2)輸入設(shè)備;(3)存儲(chǔ)設(shè)備;(4)輸出設(shè)備;以及(5)被稱(chēng)作總線的通信網(wǎng)絡(luò),它將系統(tǒng)的所有要素連接起來(lái)并將系統(tǒng)與外
10、界連接起來(lái)。四、編程一個(gè)程序就是一系列指令,告訴計(jì)算機(jī)硬件對(duì)數(shù)據(jù)執(zhí)行什么樣的操作。程序可以內(nèi)嵌在硬件本身里,或以軟件的形式獨(dú)立存在。在一些專(zhuān)門(mén)或“專(zhuān)用”計(jì)算機(jī)中,操作指令被嵌入其電路里;常見(jiàn)的例子有計(jì)算器、手表、汽車(chē)發(fā)動(dòng)機(jī)和微波爐中的微型計(jì)算機(jī)。另一方面,通用計(jì)算機(jī)盡管含有一些內(nèi)置的程序(在只讀存儲(chǔ)器中)或者指令(在處理器芯片中),但依靠外部程序來(lái)執(zhí)行有用的任務(wù)。計(jì)算機(jī)一旦被編程,就只能做在任何特定時(shí)刻控制它的軟件所允許它做的事情。廣泛使用的軟件包括一系列各種各樣的應(yīng)用程序告訴計(jì)算機(jī)如何執(zhí)行各種任務(wù)的指令。五、未來(lái)的發(fā)展計(jì)算機(jī)發(fā)展的一個(gè)持續(xù)不斷的趨勢(shì)是微小型化,亦即將越來(lái)越多的電路元件壓縮在越
11、來(lái)越小的芯片空間內(nèi)的努力。研究人員也在設(shè)法利用超導(dǎo)性來(lái)提高電路的功能速度。超導(dǎo)性是在超低溫條件下在某些材料中觀察到的電阻減小現(xiàn)象。計(jì)算機(jī)發(fā)展的另一個(gè)趨勢(shì)是“第五代”計(jì)算機(jī)的研制工作,亦即研制可以解決復(fù)雜問(wèn)題而且其解決方法用“創(chuàng)造性的”這個(gè)詞來(lái)形容或許最終名副其實(shí)的計(jì)算機(jī),理想的目標(biāo)是真正的人工智能。正在積極探索的一條道路是并行處理計(jì)算,亦即利用許多芯片來(lái)同時(shí)執(zhí)行數(shù)個(gè)不同的任務(wù)。一種重要的并行處理方法是模仿神經(jīng)系統(tǒng)結(jié)構(gòu)的神經(jīng)網(wǎng)絡(luò)。另一個(gè)持續(xù)不斷的趨勢(shì)是計(jì)算機(jī)聯(lián)網(wǎng)的增加。計(jì)算機(jī)聯(lián)網(wǎng)現(xiàn)在使用由衛(wèi)星和電纜鏈路構(gòu)成的世界范圍的數(shù)據(jù)通信系統(tǒng),來(lái)將全球的計(jì)算機(jī)連在一起。此外,大量的研究工作還投入在探索“光”
12、計(jì)算機(jī)的可能性上這種硬件處理的不是電脈沖而是快得多的光脈沖。第二單元:計(jì)算機(jī)體系結(jié)構(gòu)課文A:計(jì)算機(jī)硬件一、引言計(jì)算機(jī)硬件是計(jì)算機(jī)運(yùn)行所需要的設(shè)備,由可被物理操縱的部件組成。這些部件的功能一般分為3個(gè)主要類(lèi)別:輸入、輸出和存儲(chǔ)。這些類(lèi)別的部件與微處理器相連接,特別是與計(jì)算機(jī)的中央處理器相連接。中央處理器系電子線路,它通過(guò)稱(chēng)為總線的線路或電路來(lái)提供計(jì)算能力和對(duì)計(jì)算機(jī)進(jìn)行控制。另一方面,軟件是計(jì)算機(jī)用來(lái)處理數(shù)據(jù)的一套指令,如文字處理程序或電子游戲。這些程序通常被存儲(chǔ)起來(lái),并由計(jì)算機(jī)硬件調(diào)入和調(diào)出中央處理器。軟件也控制著硬件如何利用:例如,如何從存儲(chǔ)設(shè)備中檢索信息。輸入與輸出硬件的交互是由基本輸入/輸
13、出系統(tǒng)(BIOS)軟件控制的。盡管微處理器在技術(shù)上仍被認(rèn)為是硬件,但其部分功能也與計(jì)算機(jī)軟件有關(guān)系。既然微處理器同時(shí)具有硬件與軟件的特征,它們因此經(jīng)常被稱(chēng)作固件。二、輸入硬件輸入硬件由給計(jì)算機(jī)提供信息和指令的外部設(shè)備亦即計(jì)算機(jī)中央處理器以外的部件組成。光筆是帶有光敏端頭的輸入筆,用來(lái)在計(jì)算機(jī)顯示屏上直接寫(xiě)畫(huà),或者通過(guò)按光筆上的夾子或用光筆接觸屏幕來(lái)在屏幕上選擇信息。這種筆含有光傳感器,用于識(shí)別筆所經(jīng)過(guò)的屏幕部分。鼠標(biāo)是為一只手抓握而設(shè)計(jì)的指示設(shè)備。它在底部有一個(gè)檢測(cè)裝置(通常是一個(gè)圓球),使用戶能夠通過(guò)在一個(gè)平面上移動(dòng)鼠標(biāo)來(lái)控制屏幕上指針或光標(biāo)的運(yùn)動(dòng)。該裝置滑過(guò)平面時(shí),光標(biāo)隨著在屏幕上移動(dòng)。要
14、在屏幕上選擇項(xiàng)目或命令,用戶就點(diǎn)擊鼠標(biāo)上的按鈕。操縱桿是由一根桿子組成的指示設(shè)備,該桿以向多個(gè)方向移動(dòng)來(lái)操縱計(jì)算機(jī)屏幕上的光標(biāo)或者其他圖形對(duì)象。鍵盤(pán)是一個(gè)像打字機(jī)的設(shè)備,它使用戶得以向計(jì)算機(jī)鍵入文本和命令。有些鍵盤(pán)有特殊功能鍵或集成指示設(shè)備,如軌跡球或者可以讓用戶通過(guò)手指的移動(dòng)來(lái)移動(dòng)屏幕上光標(biāo)的觸敏區(qū)。光掃描儀利用光感應(yīng)設(shè)備將圖片或文本等形式的圖像轉(zhuǎn)換成計(jì)算機(jī)能夠處理的電子信號(hào)。例如,一張照片可以掃入一臺(tái)計(jì)算機(jī),然后包括在該計(jì)算機(jī)創(chuàng)建的文本文件中。兩種最常見(jiàn)的掃描儀類(lèi)型是平板掃描儀和手持式掃描儀,前者類(lèi)似一臺(tái)辦公室用復(fù)印機(jī),后者用手動(dòng)的方式從要處理的圖像上掃過(guò)。麥克風(fēng)是將聲音轉(zhuǎn)換成可被計(jì)算機(jī)存
15、儲(chǔ)、處理和回放的信號(hào)的設(shè)備。語(yǔ)音識(shí)別模塊是將話語(yǔ)轉(zhuǎn)換成計(jì)算機(jī)能夠識(shí)別和處理的信息的設(shè)備。調(diào)制解調(diào)器代表調(diào)制器解調(diào)器,是將計(jì)算機(jī)與電話線連接、允許信息傳送給或接收自另一臺(tái)計(jì)算機(jī)的設(shè)備。每臺(tái)發(fā)送或接收信息的計(jì)算機(jī)都必須與調(diào)制解調(diào)器相連接。一臺(tái)計(jì)算機(jī)發(fā)送的信息由調(diào)制解調(diào)器轉(zhuǎn)換成音頻信號(hào),然后通過(guò)電話線傳送到接收端調(diào)制解調(diào)器,由其將信號(hào)轉(zhuǎn)換成接收端計(jì)算機(jī)能夠理解的信息。三、輸出硬件輸出硬件由將信息從計(jì)算機(jī)中央處理器傳給計(jì)算機(jī)用戶的外部設(shè)備構(gòu)成。視頻顯示器或屏幕將計(jì)算機(jī)生成的信息轉(zhuǎn)換成可視信息。顯示器一般有兩種形式:陰極射線管視頻屏幕和液晶顯示視頻屏幕。基于陰極射線管的屏幕或監(jiān)視器看起來(lái)就像一臺(tái)電視機(jī)。
16、從中央處理器輸出的信息,使用電子束顯示出來(lái),其過(guò)程是電子束掃描熒光屏,而熒光屏則發(fā)出光并產(chǎn)生圖像?;谝壕э@示器的屏幕將可視信息顯示在比基于陰極射線管的視頻監(jiān)視器平且小的屏幕上。液晶顯示器常常用于膝上型計(jì)算機(jī)。打印機(jī)將計(jì)算機(jī)輸出的文本和圖像打印在紙上。點(diǎn)陣打印機(jī)使用細(xì)小的金屬絲打擊色帶,從而形成字符。激光打印機(jī)使用光束在磁鼓上畫(huà)圖像,然后由磁鼓吸起稱(chēng)為墨粉的微小黑粒。墨粉熔凝到紙上,形成圖像。噴墨打印機(jī)將小墨滴噴射到紙上,形成字符和圖像。四、存儲(chǔ)硬件存儲(chǔ)硬件永久性地存儲(chǔ)信息和程序,供計(jì)算機(jī)檢索。兩種主要的存儲(chǔ)設(shè)備是磁盤(pán)驅(qū)動(dòng)器和存儲(chǔ)器。磁盤(pán)驅(qū)動(dòng)器有幾種類(lèi)型:硬盤(pán)、軟盤(pán)、磁光盤(pán)和光盤(pán)。硬盤(pán)驅(qū)動(dòng)器將
17、信息存儲(chǔ)在盤(pán)中嵌入的磁性顆粒中。硬盤(pán)驅(qū)動(dòng)器通常是計(jì)算機(jī)的固定部分,能存儲(chǔ)大量的信息并對(duì)其進(jìn)行非常快速的檢索。軟盤(pán)驅(qū)動(dòng)器也將信息存儲(chǔ)在磁性顆粒中,但這些顆粒是嵌入可移動(dòng)的盤(pán)中的,而這些盤(pán)既可能是軟的也可能是硬的。軟盤(pán)比硬盤(pán)存儲(chǔ)的信息少,檢索該信息的速度也慢得多。磁光盤(pán)驅(qū)動(dòng)器將信息存儲(chǔ)在對(duì)激光和磁場(chǎng)均敏感的可移動(dòng)盤(pán)上。它們可存儲(chǔ)的信息通常與硬盤(pán)一樣多,但檢索速度稍微慢一點(diǎn)。由反射材料制成的光盤(pán),其表面燒蝕出凹陷區(qū)。光盤(pán)驅(qū)動(dòng)器(只讀光盤(pán)存儲(chǔ)器,CD-ROM)就是將信息存儲(chǔ)于此。存儲(chǔ)在只讀光盤(pán)存儲(chǔ)器上的信息不能擦除或用新信息蓋寫(xiě)。它們能夠存儲(chǔ)和硬盤(pán)驅(qū)動(dòng)器差不多的信息量,但信息檢索速度比其慢。存儲(chǔ)器指存
18、儲(chǔ)信息供中央處理器快速檢索的計(jì)算機(jī)芯片。隨機(jī)存儲(chǔ)器(RAM)用來(lái)存儲(chǔ)操作計(jì)算機(jī)程序的信息和指令。通常,程序由磁盤(pán)驅(qū)動(dòng)器的存儲(chǔ)區(qū)調(diào)到隨機(jī)存儲(chǔ)器中。隨機(jī)存儲(chǔ)器也稱(chēng)作易失性存儲(chǔ)器,因?yàn)楫?dāng)計(jì)算機(jī)的電源關(guān)閉時(shí),計(jì)算機(jī)芯片中的信息隨著丟失。只讀存儲(chǔ)器(ROM)包含必須永久性可供計(jì)算機(jī)操作使用的關(guān)鍵信息和軟件,如從開(kāi)機(jī)到關(guān)機(jī)一直指揮計(jì)算機(jī)運(yùn)行的操作系統(tǒng)。只讀存儲(chǔ)器叫做非易失性存儲(chǔ)器,因?yàn)楫?dāng)計(jì)算機(jī)的電源關(guān)閉時(shí),存儲(chǔ)芯片中的信息不會(huì)丟失。有些設(shè)備有不止一種用途。例如,軟盤(pán)也可用作輸入設(shè)備,如果它們含有計(jì)算機(jī)用戶要使用和處理的信息的話。此外,它們也可用作輸出設(shè)備,如果用戶想將計(jì)算結(jié)果存儲(chǔ)在它們上面的話。五、硬件的
19、連接要想運(yùn)轉(zhuǎn),硬件需要物理連接,使部件之間能夠通信和交互??偩€提供了一種常見(jiàn)的互連系統(tǒng)。它由一組導(dǎo)線或電路組成,在計(jì)算機(jī)的內(nèi)部組成部分之間協(xié)調(diào)和移動(dòng)信息。計(jì)算機(jī)總線由兩條通道組成:一條由中央處理器用來(lái)給數(shù)據(jù)定位,叫做地址總線;另一條用來(lái)將該數(shù)據(jù)送往那個(gè)地址,叫做數(shù)據(jù)總線??偩€可用兩個(gè)特征來(lái)描述:一次可以處理的信息量稱(chēng)為總線寬度,以及傳送這些數(shù)據(jù)的速度。串行連接是一根或一組導(dǎo)線,用于將信息從中央處理器傳送到外部設(shè)備,如鼠標(biāo)、鍵盤(pán)、調(diào)制解調(diào)器、掃描儀和一些類(lèi)型的打印機(jī)。這種連接一次只能傳送一段數(shù)據(jù),因此比較慢。使用串行連接的好處在于它能提供遠(yuǎn)距離的有效連接。并行連接使用多組導(dǎo)線來(lái)同時(shí)傳送數(shù)個(gè)信息塊
20、。多數(shù)掃描儀和打印機(jī)使用這種連接方式。并行連接比串行連接速度快得多,但它僅限于中央處理器和外部設(shè)備之間不到3米(10英尺)的距離。第三單元:計(jì)算機(jī)語(yǔ)言與編程課文A:編程語(yǔ)言一、引言在計(jì)算機(jī)科學(xué)中,編程語(yǔ)言是用于編寫(xiě)可由計(jì)算機(jī)運(yùn)行的一系列指令(計(jì)算機(jī)程序)的人工語(yǔ)言。與英語(yǔ)等自然語(yǔ)言相類(lèi)似,編程語(yǔ)言有詞匯、語(yǔ)法和句法。然而,自然語(yǔ)言不適合為計(jì)算機(jī)編程,因?yàn)樗鼈儠?huì)引起歧義,也就是說(shuō)它們的詞匯和語(yǔ)法結(jié)構(gòu)可能被用多種方式進(jìn)行解釋。用于計(jì)算機(jī)編程的語(yǔ)言必須有簡(jiǎn)單的邏輯結(jié)構(gòu),它們的語(yǔ)法、拼寫(xiě)和標(biāo)點(diǎn)符號(hào)規(guī)則必須精確。編程語(yǔ)言在復(fù)雜性和通用程度上差異很大。一些編程語(yǔ)言是為了處理特定類(lèi)型的計(jì)算問(wèn)題或?yàn)榱擞糜谔囟?/p>
21、型號(hào)的計(jì)算機(jī)系統(tǒng)而編寫(xiě)的。例如,F(xiàn)ORTRAN和COBOL等編程語(yǔ)言是為解決某些普遍的編程問(wèn)題類(lèi)型而編寫(xiě)的FORTRAN是為了科學(xué)領(lǐng)域的應(yīng)用,而COBOL是為了商業(yè)領(lǐng)域的應(yīng)用。盡管這些語(yǔ)言旨在處理特定類(lèi)型的計(jì)算機(jī)問(wèn)題,但它們具有很高的可移植性,也就是說(shuō)它們可以用來(lái)為多種類(lèi)型的計(jì)算機(jī)編程。其他的語(yǔ)言,如機(jī)器語(yǔ)言,是為一種特定型號(hào)的計(jì)算機(jī)系統(tǒng),甚至是一臺(tái)特定的計(jì)算機(jī),在某些研究領(lǐng)域使用而編寫(xiě)的。最常用的編程語(yǔ)言具有很高的可移植性,可以用于有效地解決不同類(lèi)型的計(jì)算問(wèn)題。像C、PASCAL和BASIC這樣的語(yǔ)言就屬于這一范疇。二、語(yǔ)言類(lèi)型編程語(yǔ)言可分為低級(jí)語(yǔ)言和高級(jí)語(yǔ)言。低級(jí)編程語(yǔ)言或機(jī)器語(yǔ)言,是編程
22、語(yǔ)言中最基礎(chǔ)的類(lèi)型,可以被計(jì)算機(jī)直接理解。機(jī)器語(yǔ)言視計(jì)算機(jī)制造商與型號(hào)不同而有所區(qū)別。高級(jí)語(yǔ)言是必須首先翻譯成機(jī)器語(yǔ)言計(jì)算機(jī)才能理解和處理的編程語(yǔ)言。C、C+、PASCAL和FORTRAN都是高級(jí)語(yǔ)言的例子。匯編語(yǔ)言是中級(jí)語(yǔ)言,非常接近于機(jī)器語(yǔ)言,沒(méi)有其他高級(jí)語(yǔ)言所表現(xiàn)出的語(yǔ)言復(fù)雜程度,但仍然得翻譯成機(jī)器語(yǔ)言。1、機(jī)器語(yǔ)言在機(jī)器語(yǔ)言中,指令被寫(xiě)成計(jì)算機(jī)能夠直接理解的1和0(稱(chēng)作位)序列。一條機(jī)器語(yǔ)言指令一般告訴計(jì)算機(jī)4件事:(1)到計(jì)算機(jī)主存(隨機(jī)存儲(chǔ)器)的什么位置去找一兩個(gè)數(shù)字或簡(jiǎn)單的數(shù)據(jù)片;(2)要執(zhí)行的簡(jiǎn)單操作,如將兩個(gè)數(shù)字相加;(3)在主存的什么位置存放該簡(jiǎn)單操作的結(jié)果;(4)到什么位
23、置去找下一條要執(zhí)行的指令。盡管所有的可執(zhí)行程序最終都是以機(jī)器語(yǔ)言的形式被計(jì)算機(jī)讀入的,但它們并非都是用機(jī)器語(yǔ)言編寫(xiě)的。直接用機(jī)器語(yǔ)言編程極端困難,因?yàn)橹噶钍?和1的序列。一條典型的機(jī)器語(yǔ)言指令可能寫(xiě)成100101100 1011,意思是把存儲(chǔ)寄存器A的內(nèi)容加到存儲(chǔ)寄存器B的內(nèi)容中。2、高級(jí)語(yǔ)言高級(jí)語(yǔ)言是相對(duì)復(fù)雜的一系列語(yǔ)句,它們使用來(lái)自人類(lèi)語(yǔ)言的詞匯和句法。高級(jí)語(yǔ)言比匯編語(yǔ)言或機(jī)器語(yǔ)言類(lèi)似于正常的人類(lèi)語(yǔ)言,因此用高級(jí)語(yǔ)言來(lái)編寫(xiě)復(fù)雜的程序比較容易。這些編程語(yǔ)言可以更快地開(kāi)發(fā)更大和更復(fù)雜的程序。然而,高級(jí)語(yǔ)言必須由稱(chēng)為編譯器的另外一種程序翻譯成機(jī)器語(yǔ)言,計(jì)算機(jī)才能理解它們。因?yàn)檫@個(gè)原因,與用匯編語(yǔ)
24、言編寫(xiě)的程序相比較,用高級(jí)語(yǔ)言編寫(xiě)的程序可能運(yùn)行時(shí)間長(zhǎng),占用內(nèi)存多。3、匯編語(yǔ)言計(jì)算機(jī)程序員通過(guò)使用匯編語(yǔ)言,使機(jī)器語(yǔ)言程序比較容易編寫(xiě)。在匯編語(yǔ)言中,每個(gè)語(yǔ)句大致對(duì)應(yīng)于一條機(jī)器語(yǔ)言指令。匯編語(yǔ)言的語(yǔ)句是借助易于記憶的命令編寫(xiě)的。在一個(gè)典型的匯編語(yǔ)言語(yǔ)句中,把存儲(chǔ)寄存器A的內(nèi)容加到存儲(chǔ)寄存器B的內(nèi)容中這一命令,可能寫(xiě)成ADD B, A。匯編語(yǔ)言與機(jī)器語(yǔ)言具有某些共同的特征。例如,對(duì)特定的位進(jìn)行操控,用匯編語(yǔ)言和機(jī)器語(yǔ)言都是可行的。當(dāng)盡量減少程序的運(yùn)行時(shí)間很重要時(shí),程序員就使用匯編語(yǔ)言,因?yàn)閺膮R編語(yǔ)言到機(jī)器語(yǔ)言的翻譯相對(duì)簡(jiǎn)單。匯編語(yǔ)言也用于計(jì)算機(jī)的某個(gè)部分必須被直接控制的情況,如監(jiān)視器上的單個(gè)點(diǎn)
25、或者單個(gè)字符向打印機(jī)的流動(dòng)。三、高級(jí)語(yǔ)言的分類(lèi)高級(jí)語(yǔ)言通常分為面向過(guò)程語(yǔ)言、函數(shù)式語(yǔ)言、面向?qū)ο笳Z(yǔ)言或邏輯語(yǔ)言。當(dāng)今最常見(jiàn)的高級(jí)語(yǔ)言是面向過(guò)程語(yǔ)言。在這種語(yǔ)言中,執(zhí)行某個(gè)完整功能的一個(gè)或多個(gè)相關(guān)的語(yǔ)句塊組成一個(gè)程序模塊或過(guò)程,而且被給予諸如“過(guò)程A”一類(lèi)名稱(chēng)。如果在程序的其他地方需要同樣的操作序列,可以使用一個(gè)簡(jiǎn)單的語(yǔ)句調(diào)回這個(gè)過(guò)程。實(shí)質(zhì)上,一個(gè)過(guò)程就是一個(gè)小型程序。一個(gè)大型程序可以通過(guò)將執(zhí)行不同任務(wù)的過(guò)程組合在一起而構(gòu)成。過(guò)程語(yǔ)言使程序變得比較短,而且比較容易被計(jì)算機(jī)讀取,但要求程序員將每個(gè)過(guò)程都設(shè)計(jì)得足夠通用,能用于不同的情況。函數(shù)式語(yǔ)言像對(duì)待數(shù)學(xué)函數(shù)一樣對(duì)待過(guò)程,并允許像處理程序中的任何
26、其他數(shù)據(jù)一樣處理它們。這就使程序構(gòu)造在更高、更嚴(yán)密的水平上得以實(shí)現(xiàn)。函數(shù)式語(yǔ)言也允許變量在程序運(yùn)行過(guò)程中可以被用戶指定和更改的數(shù)據(jù)符號(hào)只被賦值一次。這樣,通過(guò)減少對(duì)語(yǔ)句執(zhí)行的確切順序給予關(guān)注的必要性,就簡(jiǎn)化了編程,因?yàn)橐粋€(gè)變量沒(méi)有必要每次在一個(gè)程序語(yǔ)句中用到,都重新聲明或重新說(shuō)明。來(lái)自函數(shù)式語(yǔ)言的許多思想已經(jīng)成為許多現(xiàn)代過(guò)程語(yǔ)言的關(guān)鍵部分。面向?qū)ο笳Z(yǔ)言是函數(shù)式語(yǔ)言的發(fā)展結(jié)果。在面向?qū)ο笳Z(yǔ)言中,用來(lái)編寫(xiě)程序的代碼和由程序處理的數(shù)據(jù),組合成叫做對(duì)象的單元。對(duì)象進(jìn)一步組合成類(lèi),而類(lèi)則定義對(duì)象必須具有的屬性。類(lèi)的一個(gè)簡(jiǎn)單例子就是書(shū)這個(gè)類(lèi)。這個(gè)類(lèi)中的對(duì)象可能是小說(shuō)和短篇小說(shuō)。對(duì)象還有某些與其相關(guān)的功能,
27、稱(chēng)為方法。計(jì)算機(jī)通過(guò)使用一個(gè)對(duì)象的某種方法來(lái)訪問(wèn)該對(duì)象。方法對(duì)對(duì)象中的數(shù)據(jù)執(zhí)行某種操作,然后將值返回給計(jì)算機(jī)。對(duì)象的類(lèi)也可進(jìn)一步組合成層,而在層中一個(gè)類(lèi)的對(duì)象可繼承另一個(gè)類(lèi)的方法。面向?qū)ο笳Z(yǔ)言提供的這種結(jié)構(gòu),使該語(yǔ)言對(duì)于復(fù)雜的編程任務(wù)非常有用。邏輯語(yǔ)言將邏輯用作其數(shù)學(xué)基礎(chǔ)。邏輯程序由事實(shí)組和“如果則”規(guī)則構(gòu)成,“如果則”規(guī)則具體說(shuō)明一組事實(shí)如何可以從其他事實(shí)組中推斷出來(lái),例如:如果X語(yǔ)句為真,則Y語(yǔ)句為假。在這樣一個(gè)程序的執(zhí)行過(guò)程中,一條輸入語(yǔ)句可以按照邏輯從程序中的其他語(yǔ)句推斷出來(lái)。許多人工智能程序使用這種語(yǔ)言編寫(xiě)。四、語(yǔ)言結(jié)構(gòu)與成分編程語(yǔ)言使用特定類(lèi)型的語(yǔ)句或指令,來(lái)給程序提供功能結(jié)構(gòu)。程
28、序中的一個(gè)語(yǔ)句是表達(dá)一個(gè)簡(jiǎn)單想法的基本句子它的目的是給計(jì)算機(jī)一條基本指令。語(yǔ)句定義所允許的數(shù)據(jù)類(lèi)型、數(shù)據(jù)如何處理以及過(guò)程和函數(shù)的工作方式。程序員使用語(yǔ)句來(lái)操控編程語(yǔ)言的常見(jiàn)成分,如變量和宏(程序中的小程序段)。數(shù)據(jù)聲明語(yǔ)句給稱(chēng)為變量的那些程序元素以名稱(chēng)和屬性。變量在程序中可以賦予不同的值。變量可以具有的屬性稱(chēng)為類(lèi)型,它們包括:變量中能保存哪些可能的值;這些值中使用何種程度的數(shù)值精度;以及一個(gè)變量可以如何以有組織結(jié)構(gòu)的方式如以表或數(shù)組的形式表示一組比較簡(jiǎn)單的值。在許多編程語(yǔ)言中,一個(gè)關(guān)鍵的數(shù)據(jù)類(lèi)型是指針。指針變量本身沒(méi)有值,而是含有計(jì)算機(jī)可以用來(lái)查找某個(gè)其他變量的信息也就是說(shuō),它們指向另一個(gè)變量
29、。表達(dá)式是語(yǔ)句的一段,用于描述要對(duì)一些程序變量執(zhí)行的一系列計(jì)算操作,如X+Y/Z,其中X、Y和Z為變量,加法和除法是計(jì)算操作。賦值語(yǔ)句給一個(gè)變量賦予得自某個(gè)表達(dá)式的值,而條件語(yǔ)句則指定要被測(cè)試、然后用于選擇接下來(lái)應(yīng)該執(zhí)行的其他語(yǔ)句的表達(dá)式。過(guò)程和函數(shù)語(yǔ)句將某些代碼塊定義為以后可在程序中回調(diào)的過(guò)程或函數(shù)。這些語(yǔ)句也定義程序員可選的變量和參數(shù)種類(lèi),以及當(dāng)表達(dá)式訪問(wèn)過(guò)程或函數(shù)時(shí)代碼所返回的值的類(lèi)型。許多編程語(yǔ)言也容許叫做宏的小翻譯程序。宏將那些用程序員定義的語(yǔ)言結(jié)構(gòu)編寫(xiě)的代碼段翻譯成編程語(yǔ)言可以理解的語(yǔ)句。五、歷史編程語(yǔ)言幾乎可以追溯到20世紀(jì)40年代數(shù)字計(jì)算機(jī)發(fā)明之時(shí)。隨著商用計(jì)算機(jī)的推出,最早的
30、匯編語(yǔ)言出現(xiàn)于20世紀(jì)50年代末。最早的過(guò)程語(yǔ)言是在20世紀(jì)50年代末到60年代初開(kāi)發(fā)的:約翰.巴克斯創(chuàng)造了FORTRAN語(yǔ)言,接著格雷斯.霍珀創(chuàng)造了COBOL語(yǔ)言。第一種函數(shù)式語(yǔ)言是LISP,由約翰.麥卡錫于20世紀(jì)50年代末編寫(xiě)。所有這3種語(yǔ)言今天仍在廣泛使用,但經(jīng)歷過(guò)大量更新。20世紀(jì)60年代末,出現(xiàn)了最早的面向?qū)ο笳Z(yǔ)言,如SIMULA語(yǔ)言。邏輯語(yǔ)言在20世紀(jì)70年代中期隨著PROLOG語(yǔ)言的推出而變得廣為人知,PROLOG語(yǔ)言是一種用于編寫(xiě)人工智能軟件的語(yǔ)言。在20世紀(jì)70年代,過(guò)程語(yǔ)言繼續(xù)發(fā)展,出現(xiàn)了ALGOL、BASIC、PASCAL、C和Ada等語(yǔ)言。SMALLTALK語(yǔ)言是一種
31、具有高度影響力的面向?qū)ο笳Z(yǔ)言,它導(dǎo)致了面向?qū)ο笳Z(yǔ)言與過(guò)程語(yǔ)言在C+和更近期的JAVA語(yǔ)言中的結(jié)合。盡管純粹邏輯語(yǔ)言的流行程度已經(jīng)下降,但其以關(guān)系語(yǔ)言形式用于現(xiàn)代數(shù)據(jù)庫(kù)的變種卻變得非常重要,如結(jié)構(gòu)化查詢語(yǔ)言。第四單元:軟件開(kāi)發(fā)課文A:計(jì)算機(jī)程序一、引言計(jì)算機(jī)程序是指揮計(jì)算機(jī)執(zhí)行某種處理功能或功能組合的一套指令。要使指令得到執(zhí)行,計(jì)算機(jī)必須執(zhí)行程序,也就是說(shuō),計(jì)算機(jī)要讀取程序,然后按準(zhǔn)確的順序?qū)嵤┏绦蛑芯幋a的步驟,直至程序結(jié)束。一個(gè)程序可多次執(zhí)行,而且,取決于用戶提供給計(jì)算機(jī)的選項(xiàng)和數(shù)據(jù),每次執(zhí)行可能產(chǎn)生不同的結(jié)果。程序分為兩大類(lèi):應(yīng)用程序和操作系統(tǒng)。應(yīng)用程序直接為用戶執(zhí)行某種功能,如處理文字或玩
32、游戲。操作系統(tǒng)管理計(jì)算機(jī)以及與之相連的各種資源和設(shè)備,如隨機(jī)存儲(chǔ)器、硬盤(pán)驅(qū)動(dòng)器、監(jiān)視器、鍵盤(pán)、打印機(jī)和調(diào)制解調(diào)器,以便其他程序可以使用它們。操作系統(tǒng)的例子包括:DOS、Windows 95、OS/2和UNIX。二、程序開(kāi)發(fā)軟件設(shè)計(jì)者使用經(jīng)常被稱(chēng)為實(shí)用程序或開(kāi)發(fā)程序的專(zhuān)門(mén)應(yīng)用程序來(lái)創(chuàng)建新程序。程序員使用稱(chēng)為文本編輯程序的另一種程序,來(lái)以稱(chēng)為編程語(yǔ)言的特殊符號(hào)編寫(xiě)新程序。程序員使用文本編輯程序創(chuàng)建一個(gè)文本文件,這個(gè)文本文件是一個(gè)有序指令表,也稱(chēng)為程序源文件。構(gòu)成程序源文件的單個(gè)指令稱(chēng)為源代碼。在這個(gè)時(shí)候,一種專(zhuān)門(mén)的應(yīng)用程序?qū)⒃创a翻譯成機(jī)器語(yǔ)言或目標(biāo)代碼操作系統(tǒng)將認(rèn)作真程序并能夠執(zhí)行的一種格式。將
33、源代碼翻譯成目標(biāo)代碼的應(yīng)用程序有3種:編譯程序、解釋程序和匯編程序。這3種應(yīng)用程序有不同的操作方式,對(duì)不同類(lèi)型的編程語(yǔ)言進(jìn)行操作,但是,它們都要達(dá)到將編程語(yǔ)言翻譯成機(jī)器語(yǔ)言的相同目的。編譯程序?qū)⑹褂肍ORTRAN、C和Pascal等高級(jí)編程語(yǔ)言編寫(xiě)的文本文件一次性從源代碼翻譯成目標(biāo)代碼。這不同于BASIC等解釋執(zhí)行的語(yǔ)言所采取的方式。在解釋執(zhí)行的語(yǔ)言中,程序是隨著每條指令的執(zhí)行而逐個(gè)語(yǔ)句地翻譯成目標(biāo)代碼的。解釋執(zhí)行的語(yǔ)言的優(yōu)點(diǎn)是,它們可以立即開(kāi)始執(zhí)行程序,而不需要等到所有的源代碼都得到編譯。對(duì)程序的更改也可以相當(dāng)快地進(jìn)行,無(wú)需等到程序重新編譯完。解釋執(zhí)行的語(yǔ)言的缺點(diǎn)是,它們執(zhí)行起來(lái)慢,因?yàn)槊看?/p>
34、運(yùn)行程序,都必須對(duì)整個(gè)程序一次一條指令地翻譯。另一方面,編譯執(zhí)行的語(yǔ)言只編譯一次,因此計(jì)算機(jī)執(zhí)行起來(lái)可比解釋執(zhí)行的語(yǔ)言快得多。由于這個(gè)原因,編譯執(zhí)行的語(yǔ)言比解釋執(zhí)行的語(yǔ)言常用,而且,在專(zhuān)業(yè)和科學(xué)領(lǐng)域幾乎總是應(yīng)用編譯執(zhí)行的語(yǔ)言。另一種翻譯程序是匯編程序,它用于以匯編語(yǔ)言編寫(xiě)的程序或程序組成部分。匯編語(yǔ)言也是一種編程語(yǔ)言,但它遠(yuǎn)比其他類(lèi)型的高級(jí)語(yǔ)言類(lèi)似于機(jī)器語(yǔ)言。在匯編語(yǔ)言中,一個(gè)語(yǔ)句通??梢苑g成機(jī)器語(yǔ)言的一條指令。今天,匯編語(yǔ)言很少用來(lái)編寫(xiě)整個(gè)程序,而是最常用于程序員需要直接控制計(jì)算機(jī)某方面功能的情況下。程序經(jīng)常編寫(xiě)為一組較小的程序片,每片表示整個(gè)應(yīng)用程序的某個(gè)方面。每片獨(dú)立編譯之后,一種稱(chēng)為
35、連接程序的程序?qū)⑺蟹g好的程序片組合成一個(gè)可執(zhí)行程序。程序罕有第一次能夠正確運(yùn)行的,所以一種稱(chēng)為調(diào)試程序的程序常被用來(lái)幫助查找稱(chēng)為程序錯(cuò)誤的問(wèn)題。調(diào)試程序通常在運(yùn)行的程序中檢測(cè)到一個(gè)事件,并將程序員指引到該事件在程序代碼中的起源。Java等最近出現(xiàn)的編程系統(tǒng),采取多種方法相結(jié)合的方式創(chuàng)建和執(zhí)行程序。編譯程序取來(lái)Java源程序,并將其翻譯成中間形式。這樣的中間程序隨后通過(guò)因特網(wǎng)傳送給計(jì)算機(jī),而計(jì)算機(jī)里的解釋程序接著將中間形式作為應(yīng)用程序來(lái)執(zhí)行。三、程序元素多數(shù)程序僅由少數(shù)幾種步驟構(gòu)成,這些步驟在整個(gè)程序中在不同的上下文和以不同的組合方式多次重復(fù)。最常見(jiàn)的步驟執(zhí)行某種計(jì)算,然后按程序員指定的順序
36、,進(jìn)入程序的下一個(gè)步驟。程序經(jīng)常需要多次重復(fù)不長(zhǎng)的一系列步驟,例如:在瀏覽游戲得分表并從中找出最高得分時(shí)。這種重復(fù)的代碼序列稱(chēng)為循環(huán)。計(jì)算機(jī)具有的使其如此有用的能力之一,是它們能夠作出條件判定,并根據(jù)正在處理的數(shù)據(jù)的值執(zhí)行不同的指令。if-then-else(如果則否則)語(yǔ)句執(zhí)行這種功能,采用的方法是測(cè)試某個(gè)數(shù)據(jù)片,然后根據(jù)結(jié)果從兩個(gè)指令序列中選擇一個(gè)。這些選擇對(duì)象中的指令之一可能是一個(gè)goto語(yǔ)句,用以指引計(jì)算機(jī)從程序的另一個(gè)部分選擇下一條指令。例如,一個(gè)程序可能比較兩個(gè)數(shù),并視比較結(jié)果而分支到程序的另一個(gè)部分:If x is greater than ythengoto instructi
37、on #10else continue程序經(jīng)常不止一次地使用特定的一系列步驟。這樣的一系列步驟可以組合成一個(gè)子例程,而子例程根據(jù)需要可在主程序的不同部分進(jìn)行調(diào)用或訪問(wèn)。每次調(diào)用一個(gè)子例程,計(jì)算機(jī)都會(huì)記住該調(diào)用發(fā)生時(shí)自己在程序中所處的位置,以便在運(yùn)行完這個(gè)子例程后還能夠回到那里。在每次調(diào)用之前,程序可以指定子例程使用不同的數(shù)據(jù),從而允許一個(gè)通用性很強(qiáng)的代碼片只編寫(xiě)一次,但以多種方式使用。大多數(shù)程序使用幾種不同的子例程。其中最常用的是函數(shù)、過(guò)程、庫(kù)、系統(tǒng)例程以及設(shè)備驅(qū)動(dòng)程序。函數(shù)是一種短的子例程,用來(lái)計(jì)算某個(gè)值,如角的計(jì)算,而該值計(jì)算機(jī)僅用一條基本指令無(wú)法計(jì)算。過(guò)程執(zhí)行的是比較復(fù)雜的功能,如給一組
38、名字排序。庫(kù)是為多種不同程序使用而編寫(xiě)的子例程。系統(tǒng)例程類(lèi)似于庫(kù)程序,但實(shí)際上用于操作系統(tǒng)。它們?yōu)閼?yīng)用程序提供某種服務(wù),如打印一行文字。設(shè)備驅(qū)動(dòng)程序是一種系統(tǒng)例程,它們加到操作系統(tǒng)中,以使計(jì)算機(jī)能夠與掃描儀、調(diào)制解調(diào)器或打印機(jī)等新設(shè)備通信。設(shè)備驅(qū)動(dòng)程序常常具有可以作為應(yīng)用程序直接執(zhí)行的特征。這使用戶得以直接控制設(shè)備。這一點(diǎn)很有用,例如:在彩色打印機(jī)更換墨盒后需要重新調(diào)整以達(dá)到最佳打印質(zhì)量的情況下。四、程序功能現(xiàn)代計(jì)算機(jī)通常將程序存儲(chǔ)在計(jì)算機(jī)可以隨機(jī)訪問(wèn)的某種形式的磁性存儲(chǔ)介質(zhì)上,如固定放在計(jì)算機(jī)內(nèi)的硬盤(pán)或者便攜式軟盤(pán)。這些磁盤(pán)上稱(chēng)為目錄的額外信息,指明盤(pán)上各種程序的名稱(chēng)、它們寫(xiě)入盤(pán)中的時(shí)間以及
39、它們?cè)诖疟P(pán)介質(zhì)上的起始位置。用戶命令計(jì)算機(jī)執(zhí)行一個(gè)特定應(yīng)用程序時(shí),操作系統(tǒng)就瀏覽這些目錄,找到程序,并將一個(gè)副本讀入隨機(jī)存儲(chǔ)器。操作系統(tǒng)然后命令中央處理器開(kāi)始執(zhí)行程序開(kāi)頭的指令。程序開(kāi)頭的指令為計(jì)算機(jī)處理信息作好準(zhǔn)備,其方法是在隨機(jī)存儲(chǔ)器中找到空閑存儲(chǔ)單元來(lái)容納工作數(shù)據(jù),從盤(pán)中檢索用戶指出的標(biāo)準(zhǔn)選項(xiàng)和默認(rèn)值的副本,并在監(jiān)視器上繪制初始顯示。應(yīng)用程序通過(guò)調(diào)用系統(tǒng)例程來(lái)對(duì)用戶輸入的任何信息都要求一個(gè)副本。操作系統(tǒng)將如此輸入的任何數(shù)據(jù)都轉(zhuǎn)換成標(biāo)準(zhǔn)的內(nèi)部形式。應(yīng)用程序然后使用該信息決定下一步干什么,如執(zhí)行某項(xiàng)期望的處理功能像重新格式化一頁(yè)文本或從盤(pán)上的另一個(gè)文件獲取一些額外信息。兩種情況無(wú)論是哪一種,
40、都要調(diào)用其他系統(tǒng)例程,以事實(shí)上完成結(jié)果的顯示或?qū)ΡP(pán)上文件的訪問(wèn)。運(yùn)行結(jié)束或接到退出的提示時(shí),應(yīng)用程序進(jìn)行進(jìn)一步的系統(tǒng)調(diào)用,以確保所有需要保存的數(shù)據(jù)已寫(xiě)回磁盤(pán)。然后,應(yīng)用程序向操作系統(tǒng)進(jìn)行最后一次系統(tǒng)調(diào)用,指明它已運(yùn)行結(jié)束。操作系統(tǒng)接下來(lái)釋放隨機(jī)存儲(chǔ)器和該應(yīng)用程序使用的任何設(shè)備,并等待用戶的命令,以開(kāi)始運(yùn)行另一個(gè)程序。五、歷史人們以程序的形式存儲(chǔ)指令序列已經(jīng)有幾個(gè)世紀(jì)了。18世紀(jì)的音樂(lè)盒和19世紀(jì)末與20世紀(jì)初的自動(dòng)鋼琴,就可以播放音樂(lè)程序。這些程序以一系列金屬針或紙孔的形式存儲(chǔ),每一行(針或孔)表示何時(shí)演奏一個(gè)音符,而針或孔則表明此時(shí)演奏什么音符。19世紀(jì)初,隨著法國(guó)發(fā)明家約瑟夫瑪麗雅卡爾發(fā)明
41、由穿孔卡片控制的織機(jī),對(duì)物理設(shè)備更精巧的控制變得常見(jiàn)了。在編織特定圖案的過(guò)程中,織機(jī)的各個(gè)部分得進(jìn)行機(jī)械定位。為了使這個(gè)過(guò)程自動(dòng)化,雅卡爾使用一張紙質(zhì)卡片代表織機(jī)的一個(gè)定位,用卡片上的孔來(lái)指示應(yīng)該執(zhí)行織機(jī)的哪種操作。整條花毯的編織可編碼到一疊這樣的卡片上,同樣的一疊卡片每次使用都會(huì)編出相同的花毯圖案。在開(kāi)發(fā)和使用的程序中,有的由24,000多張卡片構(gòu)成。世界上第一臺(tái)可編程的機(jī)器是由英國(guó)數(shù)學(xué)家和發(fā)明家查爾斯.巴比奇設(shè)計(jì)的,但他從未完全制造成該機(jī)器。這臺(tái)叫做分析機(jī)的機(jī)器,使用和雅卡爾織機(jī)類(lèi)似的穿孔卡片,來(lái)選擇每個(gè)步驟應(yīng)該執(zhí)行的具體算術(shù)運(yùn)算。插入不同的卡片組,就會(huì)改變機(jī)器執(zhí)行的運(yùn)算。這種機(jī)器幾乎能在
42、現(xiàn)代計(jì)算機(jī)中找到所有的對(duì)應(yīng)物,但它是機(jī)械化的,而非電氣化的。分析機(jī)的制造從未完成,因?yàn)橹圃焖枰募夹g(shù)當(dāng)時(shí)不存在。供分析機(jī)使用的最早卡片組式程序是由詩(shī)人拜倫勛爵的女兒、英國(guó)數(shù)學(xué)家?jiàn)W古斯塔.埃達(dá).拜倫開(kāi)發(fā)的。由于這個(gè)原因,她被公認(rèn)為世界上第一位程序員。現(xiàn)代的內(nèi)部存儲(chǔ)計(jì)算機(jī)程序概念是由美籍匈牙利數(shù)學(xué)家約翰.馮.諾伊曼于1945年首先提出來(lái)的。馮.諾伊曼的想法是,使用計(jì)算機(jī)的存儲(chǔ)器既存儲(chǔ)數(shù)據(jù)又存儲(chǔ)程序。這樣,程序可被視為數(shù)據(jù),可像數(shù)據(jù)一樣被其他程序處理。這一想法極大地簡(jiǎn)化了在計(jì)算機(jī)中存儲(chǔ)與執(zhí)行程序的任務(wù)。六、未來(lái)由于計(jì)算機(jī)使用的增加,自20世紀(jì)50年代以來(lái),計(jì)算機(jī)科學(xué)領(lǐng)域發(fā)展迅猛。作為對(duì)用戶需求和
43、技術(shù)進(jìn)步的反應(yīng),計(jì)算機(jī)程序在這一時(shí)期經(jīng)歷了許多變化。計(jì)算領(lǐng)域的新思想,如并行計(jì)算、分布式計(jì)算和人工智能,從根本上改變了一度決定程序形式與功能的傳統(tǒng)概念。致力于并行計(jì)算領(lǐng)域研究的計(jì)算機(jī)科學(xué)家們,推出了許多新的程序模型。在并行計(jì)算中,多個(gè)中央處理器同時(shí)合作處理同一個(gè)問(wèn)題。一個(gè)問(wèn)題的組成部分由不同的處理器同時(shí)處理,這樣就加快了問(wèn)題的解決速度。由于并行處理計(jì)算機(jī)的極端復(fù)雜性,以及使其盡可能有效地運(yùn)行所包含的困難,為這種系統(tǒng)設(shè)計(jì)程序的科學(xué)家和工程師面臨著許多挑戰(zhàn)。一種稱(chēng)為分布式計(jì)算的并行計(jì)算,使用多個(gè)互連計(jì)算機(jī)的中央處理器來(lái)解決問(wèn)題。用來(lái)在分布式計(jì)算應(yīng)用環(huán)境下處理信息的計(jì)算機(jī),常常通過(guò)因特網(wǎng)連接。因特網(wǎng)
44、的應(yīng)用正在成為分布式計(jì)算的一種特別有用的形式,尤其是在使用Java等編程語(yǔ)言的情況下。在這種應(yīng)用中,用戶登錄到一個(gè)站點(diǎn),并下載一個(gè)Java程序到其計(jì)算機(jī)上。該Java程序運(yùn)行時(shí),就會(huì)與其所來(lái)自的站點(diǎn)上的其他程序通信,也可以與不同計(jì)算機(jī)或站點(diǎn)上運(yùn)行的其他程序通信。人工智能研究已經(jīng)帶來(lái)其他幾種新的編程風(fēng)格。例如,邏輯程序不是由供計(jì)算機(jī)盲目執(zhí)行的單個(gè)指令構(gòu)成,而是由成套的規(guī)則組成:如果x發(fā)生,則執(zhí)行y。一種稱(chēng)為推理機(jī)的特殊程序,在向其提出一個(gè)新問(wèn)題時(shí),就使用這些規(guī)則來(lái)“推理”出一個(gè)結(jié)論。邏輯程序的用途包括自動(dòng)監(jiān)控復(fù)雜系統(tǒng)和證明數(shù)學(xué)定理。一種全然不同的計(jì)算方法稱(chēng)為神經(jīng)網(wǎng)絡(luò),在這種計(jì)算中沒(méi)有傳統(tǒng)意義上的
45、程序。神經(jīng)網(wǎng)絡(luò)是一組高度互連的簡(jiǎn)單處理單元,旨在模擬大腦。神經(jīng)網(wǎng)絡(luò)不是像傳統(tǒng)計(jì)算機(jī)那樣通過(guò)程序來(lái)指揮信息處理,而是依靠其處理單元的連接方式來(lái)處理信息。給神經(jīng)網(wǎng)絡(luò)編程的實(shí)現(xiàn)方法是,給其提供輸入與輸出數(shù)據(jù)的已知模式,并調(diào)整處理單元之間各種互連的相對(duì)重要性,直到完成所期望的模式匹配。神經(jīng)網(wǎng)絡(luò)通常在傳統(tǒng)計(jì)算機(jī)上模擬,但是,不同于傳統(tǒng)的計(jì)算機(jī)程序,神經(jīng)網(wǎng)絡(luò)具有經(jīng)驗(yàn)學(xué)習(xí)的能力。第五單元:軟件過(guò)程課文A:軟件過(guò)程模型一、引言一個(gè)軟件過(guò)程是生產(chǎn)出軟件產(chǎn)品的一系列活動(dòng)。這些活動(dòng)可能涉及使用一種像Java或C這樣的標(biāo)準(zhǔn)編程語(yǔ)言從零開(kāi)始開(kāi)發(fā)軟件。然而,開(kāi)發(fā)新軟件越來(lái)越多地使用的方法是,擴(kuò)展和修改現(xiàn)有系統(tǒng),以及配置和
46、集成現(xiàn)成軟件或系統(tǒng)組件。一個(gè)軟件過(guò)程模型是對(duì)一個(gè)軟件過(guò)程的一種抽象表示。每個(gè)過(guò)程模型都從一個(gè)特定角度表示一個(gè)過(guò)程,因此都只提供有關(guān)那個(gè)過(guò)程的部分信息。本文介紹幾種非常通用的過(guò)程模型(有時(shí)稱(chēng)為過(guò)程范例),并從體系結(jié)構(gòu)的角度描述它們。也就是說(shuō),我們看到的是過(guò)程的框架,而非具體活動(dòng)的細(xì)節(jié)。這些類(lèi)屬模型不是對(duì)軟件過(guò)程的規(guī)定性描述。確切點(diǎn)說(shuō),它們是過(guò)程的抽象,可用于解釋軟件開(kāi)發(fā)的不同方法。你可以將其視為可擴(kuò)展和調(diào)整以創(chuàng)建更為具體軟件工程過(guò)程的過(guò)程框架。這里論述的過(guò)程模型是瀑布模型、演化開(kāi)發(fā)和基于組件的軟件工程。這3種類(lèi)屬過(guò)程模型在當(dāng)前的軟件工程實(shí)踐中廣泛使用。它們不是互不相容,而是經(jīng)常一起使用,尤其是在
47、大型系統(tǒng)開(kāi)發(fā)的情況下。一個(gè)較大型系統(tǒng)內(nèi)的子系統(tǒng)可使用不同的方法開(kāi)發(fā)。因此,盡管分別討論這些模型比較方便,但應(yīng)該明白,實(shí)際上它們經(jīng)常結(jié)合使用。二、瀑布模型最早公布的軟件開(kāi)發(fā)過(guò)程模型源自比較通用的系統(tǒng)工程過(guò)程。這種模型如圖5A-1所示。由于從一個(gè)階段到另一個(gè)階段的瀑布狀級(jí)聯(lián),該模型稱(chēng)為瀑布模型或軟件生命周期。該模型的主要階段映射基本的開(kāi)發(fā)活動(dòng):1、 需求分析與定義。系統(tǒng)的服務(wù)、約束和目標(biāo)要經(jīng)過(guò)與系統(tǒng)用戶的磋商加以確定。然后,它們得到詳細(xì)定義并作為系統(tǒng)規(guī)格說(shuō)明。2、 系統(tǒng)與軟件設(shè)計(jì)。系統(tǒng)設(shè)計(jì)過(guò)程將需求劃分成需硬件或軟件系統(tǒng)實(shí)現(xiàn)的部分。該過(guò)程確立一個(gè)總的系統(tǒng)體系結(jié)構(gòu)。軟件設(shè)計(jì)涉及到確定和描述基本的軟件
48、系統(tǒng)抽象及其相互關(guān)系。3、 實(shí)現(xiàn)與單元測(cè)試。在這個(gè)階段,軟件設(shè)計(jì)被實(shí)現(xiàn)為一組程序或程序單元。單元測(cè)試涉及到驗(yàn)證每個(gè)單元是否符合其規(guī)格說(shuō)明。4、 集成與系統(tǒng)測(cè)試。單個(gè)的程序單元或程序進(jìn)行集成并作為一個(gè)完整系統(tǒng)進(jìn)行測(cè)試,以確保軟件需求已得到滿足。測(cè)試之后,軟件系統(tǒng)交付客戶。5、 運(yùn)行與維護(hù)。通常(但并非必定),這是軟件生命周期最長(zhǎng)的階段。系統(tǒng)經(jīng)過(guò)安裝投入實(shí)際使用。維護(hù)涉及到糾正在軟件生命周期前面階段沒(méi)有發(fā)現(xiàn)的錯(cuò)誤,改進(jìn)系統(tǒng)單元的實(shí)現(xiàn),并隨著新需求的發(fā)現(xiàn)增強(qiáng)系統(tǒng)的服務(wù)。原則上,每個(gè)階段的結(jié)果都要形成一份或多份經(jīng)過(guò)批準(zhǔn)的文件。前一個(gè)階段未結(jié)束,下一個(gè)階段不應(yīng)開(kāi)始。實(shí)際上,這些階段重疊并互相饋送信息。在
49、設(shè)計(jì)期間,需求方面存在的問(wèn)題得到識(shí)別;在編碼期間,設(shè)計(jì)問(wèn)題被發(fā)現(xiàn),等等。軟件過(guò)程并非一個(gè)簡(jiǎn)單的線性模型,而是涉及到一系列迭代的開(kāi)發(fā)活動(dòng)。由于編制和批準(zhǔn)文件的成本,迭代需要大筆開(kāi)銷(xiāo),而且需要做大量重復(fù)工作。因此,經(jīng)過(guò)少數(shù)迭代之后,通常應(yīng)凍結(jié)開(kāi)發(fā)的某些部分,如規(guī)格說(shuō)明,并繼續(xù)進(jìn)行后面的開(kāi)發(fā)階段。存在的問(wèn)題留待以后解決,置之不顧,或者通過(guò)編程繞過(guò)去。這樣倉(cāng)促凍結(jié)需求,可能意味圖5A-1:軟件生命周期運(yùn)行與維護(hù)集成與系統(tǒng)測(cè)試實(shí)現(xiàn)與單元測(cè)試系統(tǒng)與軟件設(shè)計(jì)需求定義著系統(tǒng)將難以滿足用戶的要求。由于使用實(shí)現(xiàn)技巧規(guī)避了設(shè)計(jì)問(wèn)題,這也可能導(dǎo)致不良的系統(tǒng)結(jié)構(gòu)。在最后的生命周期階段(運(yùn)行與維護(hù)),軟件投入使用。最初軟
50、件需求中存在的錯(cuò)誤與疏漏被發(fā)現(xiàn),程序與設(shè)計(jì)錯(cuò)誤浮現(xiàn),而且新的功能需要得到確定。因此,為保持有用性,系統(tǒng)必須演變。進(jìn)行有關(guān)更改(軟件維護(hù))可能涉及到重復(fù)以前的過(guò)程階段。瀑布模型的優(yōu)點(diǎn)在于每個(gè)階段都編制文件,而且它與其他的工程過(guò)程模型相符合。其主要問(wèn)題在于將項(xiàng)目僵硬地劃分成不同的階段。在過(guò)程的一個(gè)早期階段,必須定下決心,從而使得應(yīng)對(duì)客戶需求變化很困難。因此,只有在需求得到很好理解、在系統(tǒng)開(kāi)發(fā)期間不可能發(fā)生根本性變化的情況下,才應(yīng)使用瀑布模型。然而,瀑布模型體現(xiàn)了在其他工程項(xiàng)目中所使用的過(guò)程模型類(lèi)型。所以,基于這種方法的軟件過(guò)程仍然用于軟件開(kāi)發(fā),特別是當(dāng)有關(guān)軟件項(xiàng)目是一個(gè)較大系統(tǒng)工程項(xiàng)目的一部分時(shí)。
51、三、演化開(kāi)發(fā)演化開(kāi)發(fā)基于這樣的思想:開(kāi)發(fā)一個(gè)初始的實(shí)現(xiàn),讓其接受用戶評(píng)論,并讓其經(jīng)過(guò)多個(gè)版本的改進(jìn),一直到開(kāi)發(fā)出能夠滿足需要的系統(tǒng)(圖5A-2)。規(guī)格說(shuō)明、開(kāi)發(fā)及驗(yàn)證活動(dòng)不是分開(kāi)進(jìn)行,而是交叉進(jìn)行,各項(xiàng)活動(dòng)之間有快速的信息反饋。演化開(kāi)發(fā)有兩個(gè)基本類(lèi)型:1、 探索式開(kāi)發(fā)。在這種類(lèi)型中,過(guò)程的目標(biāo)是與客戶協(xié)作探索其需求,并交付一個(gè)最終的系統(tǒng)。開(kāi)發(fā)從業(yè)已理解的系統(tǒng)部分開(kāi)始。隨著增添客戶提出的新特征,系統(tǒng)不中間版本并行活動(dòng)圖5A-2:演化開(kāi)發(fā)描述最終版本初始版本開(kāi)發(fā)驗(yàn)證規(guī)格說(shuō)明斷演變。2、 拋棄式原型開(kāi)發(fā)。在這種類(lèi)型中,演化開(kāi)發(fā)過(guò)程的目標(biāo)是理解客戶的需求,從而為系統(tǒng)開(kāi)發(fā)比較好的需求定義。原型集中試驗(yàn)沒(méi)
52、有很好理解的客戶需求。在生產(chǎn)滿足客戶眼下需要的系統(tǒng)時(shí),軟件開(kāi)發(fā)的演化方法常常比瀑布方法有效?;谘莼椒ǖ能浖^(guò)程的優(yōu)點(diǎn)是,規(guī)格說(shuō)明可以漸進(jìn)地開(kāi)發(fā)。隨著用戶增進(jìn)對(duì)其問(wèn)題的理解,這種理解可以反映在軟件系統(tǒng)中。然而,從工程和管理的角度來(lái)看,演化方法存在兩個(gè)問(wèn)題:1、 過(guò)程缺乏可視性。管理員需要定期交付的產(chǎn)品來(lái)衡量進(jìn)度。在快速開(kāi)發(fā)系統(tǒng)的情況下,編制反映每個(gè)系統(tǒng)版本的文件不合算。2、 系統(tǒng)常常缺乏良好的結(jié)構(gòu)。不斷的更改往往會(huì)破壞軟件的結(jié)構(gòu)。吸收軟件更改變得越來(lái)越困難,越來(lái)越成本高昂。對(duì)于中小型系統(tǒng)(上至50萬(wàn)行代碼),演化方法或許是最佳的開(kāi)發(fā)方法。對(duì)于不同小組開(kāi)發(fā)系統(tǒng)不同部分的大型、復(fù)雜、長(zhǎng)壽命系統(tǒng),
53、演化開(kāi)發(fā)存在的問(wèn)題尤為嚴(yán)重。使用這種方法難以建立一個(gè)穩(wěn)定的系統(tǒng)體系結(jié)構(gòu),這使得集成各小組的貢獻(xiàn)變得很難。對(duì)于大型系統(tǒng),建議使用一種混合過(guò)程,將瀑布模型和演化開(kāi)發(fā)模型的最佳特征結(jié)合起來(lái)。這可能涉及到使用演化方法開(kāi)發(fā)一個(gè)拋棄式原型,以解決系統(tǒng)規(guī)格說(shuō)明中存在的不確定性。然后,可使用一種結(jié)構(gòu)化程度比較高的方法重新實(shí)現(xiàn)系統(tǒng)。得到很好理解的系統(tǒng)部分可使用基于瀑布模型的過(guò)程進(jìn)行規(guī)格說(shuō)明和開(kāi)發(fā)。事先難以進(jìn)行規(guī)格說(shuō)明的其他系統(tǒng)部分,如用戶界面,無(wú)例外地應(yīng)使用探索式編程方法來(lái)開(kāi)發(fā)。四、基于組件的軟件工程大多數(shù)軟件項(xiàng)目都存在某種程度的軟件復(fù)用。通常,這是非正式發(fā)生的。參加項(xiàng)目的人知道有現(xiàn)成的設(shè)計(jì)或編碼類(lèi)似于他們所需
54、的設(shè)計(jì)或編碼。他們尋找這些設(shè)計(jì)或編碼,根據(jù)需要對(duì)其進(jìn)行修改,并將其吸收進(jìn)他們的系統(tǒng)。對(duì)于使用演化方法進(jìn)行快速系統(tǒng)開(kāi)發(fā),復(fù)用常常是必要的。這種非正式復(fù)用的發(fā)生是不考慮所使用的開(kāi)發(fā)過(guò)程的。然而,在過(guò)去幾年中,出現(xiàn)了一種軟件開(kāi)發(fā)方法,這種方法使用得越來(lái)越多,它依靠復(fù)用,被稱(chēng)為基于組件的軟件工程。這種面向復(fù)用的方法依靠大量的可復(fù)用軟件組件,以及用于這些組件的某種集成框架。有時(shí),這些組件本身就是可提供文本格式化或數(shù)值計(jì)算等特定功能的系統(tǒng)(商用現(xiàn)成系統(tǒng))?;诮M件的軟件工程的類(lèi)屬過(guò)程模型如圖5A-3所示。就最初的需求規(guī)格說(shuō)明階段和驗(yàn)證階段而言,面向復(fù)用過(guò)程與其他過(guò)程相類(lèi)似,但它的中間階段與其他過(guò)程不同。這
55、些階段是:1、 組件分析。在有需求規(guī)格說(shuō)明的情況下,搜索實(shí)現(xiàn)該規(guī)格的組件。通常,不存在完全相符的組件??赡鼙皇褂玫慕M件只在某種程度上提供所要求的功能。2、 需求修改。在這個(gè)階段,使用已經(jīng)發(fā)現(xiàn)的組件的相關(guān)信息分析需求,然后修改需求以反映可用的組件。在無(wú)法進(jìn)行修改的情況下,可能重新進(jìn)入組件分析活動(dòng),以搜索可供選擇的解決方案。3、 帶復(fù)用的系統(tǒng)設(shè)計(jì)。在這個(gè)階段,設(shè)計(jì)系統(tǒng)框架或復(fù)用現(xiàn)有的框架。設(shè)計(jì)員考慮到復(fù)用的組件,并組織安排框架使其適應(yīng)復(fù)用的要求。如果得不到可復(fù)用的組件,可能得設(shè)計(jì)一些新軟件。4、 開(kāi)發(fā)與集成。無(wú)法外部獲得的軟件要進(jìn)行開(kāi)發(fā),組件和商用現(xiàn)成系統(tǒng)要集成以創(chuàng)建新的系統(tǒng)。系統(tǒng)集成在這種模型中
56、可能是開(kāi)發(fā)過(guò)程的一部分,而非一項(xiàng)分開(kāi)的活動(dòng)?;诮M件的軟件工程具有減少需要開(kāi)發(fā)的軟件量并因此降低成本與風(fēng)險(xiǎn)的明顯優(yōu)點(diǎn)。它通常也可更快地交付軟件。然而,需求方面的妥協(xié)不可避免,這可能導(dǎo)致系統(tǒng)不能滿足用戶的真正需要。此外,可復(fù)用組件的新版本不受其使用機(jī)構(gòu)的控制,因此喪失了對(duì)系統(tǒng)演變的某些控制。圖5A-3:基于組件的軟件工程需求規(guī)格說(shuō)明組件分析需求修改帶復(fù)用的系統(tǒng)設(shè)計(jì)系統(tǒng)驗(yàn)證開(kāi)發(fā)與集成第六單元:數(shù)據(jù)庫(kù)課文A:數(shù)據(jù)庫(kù)概覽一、引言數(shù)據(jù)存儲(chǔ)傳統(tǒng)上是使用單獨(dú)的沒(méi)有聯(lián)系的文件,這些文件有時(shí)稱(chēng)為平面文件。在過(guò)去,一個(gè)機(jī)構(gòu)中的每個(gè)應(yīng)用程序都使用自己的文件。例如,在一個(gè)大學(xué)中,每個(gè)部門(mén)都可能有其自己的文件集:檔案辦公室保存著關(guān)于學(xué)生信息和學(xué)生成績(jī)的文件;經(jīng)濟(jì)資助辦公室保存著
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年金融機(jī)構(gòu)與中小企業(yè)公對(duì)公信用貸款合同3篇
- 美食廣場(chǎng)食品安全檢測(cè)制度
- 交通運(yùn)輸設(shè)備采購(gòu)招投標(biāo)流程
- 網(wǎng)絡(luò)安全防護(hù)指南
- 填筑土方施工合同
- 倉(cāng)儲(chǔ)物流中心續(xù)租合同
- 2024年水電設(shè)備安全認(rèn)證與檢測(cè)服務(wù)合同3篇
- 金融行業(yè)總監(jiān)理合同模板
- 房屋共同使用權(quán)保險(xiǎn)合同
- 醫(yī)療設(shè)備采購(gòu)項(xiàng)目承攬
- 高邊坡監(jiān)控量測(cè)方案
- PEP英語(yǔ)四年級(jí)上冊(cè)Unit 4 My home 教學(xué)反思
- 帶式輸送機(jī)檢修維護(hù)通用安全技術(shù)措施實(shí)用版
- JJF 1585-2016固定污染源煙氣排放連續(xù)監(jiān)測(cè)系統(tǒng)校準(zhǔn)規(guī)范
- vpn基礎(chǔ)與應(yīng)用簡(jiǎn)介
- GB/T 23319.2-2009紡織品洗滌后扭斜的測(cè)定第2部分:機(jī)織物和針織物
- 田螺姑娘閱讀測(cè)試試題附答案
- 首都博物館參觀匯報(bào)參考課件
- 失禁性皮炎護(hù)理最新版課件
- 國(guó)家開(kāi)放大學(xué)《美學(xué)原理》形考作業(yè)1-5參考答案
- 《認(rèn)識(shí)長(zhǎng)方形》數(shù)學(xué)
評(píng)論
0/150
提交評(píng)論