版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
軟件工程第12章程序設(shè)計(jì)語言和編碼軟件工程第12章程序設(shè)計(jì)語言和編碼復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)編碼階段的任務(wù)是根據(jù)詳細(xì)設(shè)計(jì)說明書編寫程序程序設(shè)計(jì)語言的特性和程序設(shè)計(jì)風(fēng)格會(huì)深刻地影響軟件的質(zhì)量和可維護(hù)性為了保證程序編碼的質(zhì)量,程序員必須深刻理解、熟練掌握并正確地運(yùn)用程序設(shè)計(jì)語言的特性此外,還要求源程序具有良好的結(jié)構(gòu)性和良好的程序設(shè)計(jì)風(fēng)格2復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)編碼階段的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格3復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格4復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本概念程序設(shè)計(jì)語言是指用于書寫計(jì)算機(jī)程序的語言,它是一種實(shí)現(xiàn)性的軟件語言語法(syntax)表示程序的結(jié)構(gòu)或形式,即表示構(gòu)成語言的各個(gè)記號(hào)之間的組合規(guī)則,但不涉及這些記號(hào)固有的以及和使用情景有關(guān)的含義如C語言中for語句的構(gòu)成規(guī)則是:
for(表達(dá)式1;表達(dá)式2;表達(dá)式3)語句
語法中不涉及這些記號(hào)的含義,也不涉及使用情景5復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本概念程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語義(semantic)表示語言成分的固有含義,即表示按照各種方法所表示的各個(gè)記號(hào)的特定含義,但不涉及到使用者。
如上述for語句中:表達(dá)式1表示循環(huán)初值;表達(dá)式2表示循環(huán)條件;表達(dá)式3表示循環(huán)的增量;語句為循環(huán)體。整個(gè)語句的語義是:(1)計(jì)算表達(dá)式1(2)計(jì)算表達(dá)式2,若計(jì)算結(jié)果為0,則終止循環(huán);否則轉(zhuǎn)(3)(3)執(zhí)行循環(huán)體(4)計(jì)算表達(dá)式3(5)轉(zhuǎn)向(2)6復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語義(se復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語用(pragmatic)表示程序與使用情景有關(guān)的含義。語用是語言成分在程序特定執(zhí)行中的實(shí)際效用如:語言是否允許遞歸?是否要規(guī)定遞歸層數(shù)的上界?這種上界如何確定?這些都屬于語用上的問題。7復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語用(pr復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的基本成分程序設(shè)計(jì)語言基本成份可歸納為四種:數(shù)據(jù)成分、運(yùn)算成分、控制成分、傳輸成分?jǐn)?shù)據(jù)成分:指明該語言能接受的數(shù)據(jù),用以描述程序中的數(shù)據(jù)。如各種類型的變量、數(shù)組、指針、記錄等。作為程序操作的對(duì)象,具有名稱、類型和作用域等特征。使用前要對(duì)數(shù)據(jù)的這些特征加以說明。數(shù)據(jù)名稱由用戶通過標(biāo)識(shí)符命名,類型說明數(shù)據(jù)需占用存儲(chǔ)單元的多少和存放形式,作用域說明數(shù)據(jù)可以使用的范圍。8復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)以C語言為例,其數(shù)據(jù)構(gòu)造方式可分為基本類型和派生類型
9復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)以C語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)運(yùn)算成分:指明該語言允許執(zhí)行的運(yùn)算,用以描述程序中所包含的運(yùn)算。如+、-、*、/等??刂瞥煞郑褐该髟撜Z言允許的控制結(jié)構(gòu),用以表達(dá)程序中的控制構(gòu)造?;镜目刂瞥煞职ǎ喉樞蚪Y(jié)構(gòu)、條件選擇結(jié)構(gòu)和重復(fù)結(jié)構(gòu)。如下頁圖10復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)運(yùn)算成分:復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本程序控制結(jié)構(gòu)11復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本程序控復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)傳輸成分:它指明該語言允許的數(shù)據(jù)傳輸方式,在程序中可用以表達(dá)程序中數(shù)據(jù)的傳輸。例如:TurboC語言標(biāo)準(zhǔn)庫提供了兩個(gè)控制臺(tái)格式化輸入、輸出函數(shù)printf()和scanf(),這兩個(gè)函數(shù)可以在標(biāo)準(zhǔn)輸入輸出設(shè)備上以各種不同的格式讀寫數(shù)據(jù)。Printf()函數(shù)用來向標(biāo)準(zhǔn)輸出設(shè)備(屏幕)寫數(shù)據(jù),scanf()函數(shù)用來從標(biāo)準(zhǔn)輸入設(shè)備(鍵盤)上讀數(shù)據(jù)。
12復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)傳輸成分:復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的特性心理特性從設(shè)計(jì)到編碼的轉(zhuǎn)換基本上是人的活動(dòng),因此,語言的性能對(duì)程序員的心理影響將對(duì)轉(zhuǎn)換產(chǎn)生重大影響在維持現(xiàn)有機(jī)器的效率、容量和其它硬件限制條件的前提下,程序員總希望選擇簡(jiǎn)單易學(xué)、使用方便的語言,以減少程序出錯(cuò)率,提高軟件可靠性,從而提高用戶對(duì)軟件質(zhì)量的可信度13復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
在維持現(xiàn)有機(jī)器的效率、容量和其它硬件限制條件的前提下,程序員總希望選擇簡(jiǎn)單易學(xué)、使用方便的語言,以減少程序出錯(cuò)率,提高軟件可靠性,從而提高用戶對(duì)軟件質(zhì)量的可信度。
影響響程序員心理的語言特性有:一致性:指語言采用的標(biāo)記法(使用的符號(hào))協(xié)調(diào)一致的程度。如,一符多用的標(biāo)記法容易導(dǎo)致錯(cuò)誤。14復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)在維復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)二義性:對(duì)語句不同理解所產(chǎn)生的二義性將導(dǎo)致程序員對(duì)程序理解的混亂。如,
ifthenifthenelsex:=a**b**c緊致性(compactness):指程序員必須記憶的與編碼有關(guān)的信息總量。線性:人們所習(xí)慣的理解程序的次序,程序中多層的嵌套分支和循環(huán)、隨意的GOTO語句會(huì)破壞程序的線性次序。15復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)二義性:對(duì)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)工程特性程序設(shè)計(jì)語言的特性影響人們思考程序的方式,從而也限制了人們與計(jì)算機(jī)進(jìn)行通信的方式。為滿足軟件工程的需要,程序設(shè)計(jì)語言還應(yīng)該考慮:將設(shè)計(jì)翻譯成代碼的便利程度、編譯器的效率、源代碼的可移植性、配套的開發(fā)工具、軟件的可復(fù)用性和可維護(hù)性。16復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)工程特性1復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)將設(shè)計(jì)翻譯成代碼的便利程度:語言若直接支持結(jié)構(gòu)化部件、復(fù)雜的數(shù)據(jù)結(jié)構(gòu)、特殊I/O處理、按位操作和OO方法,則便于將設(shè)計(jì)轉(zhuǎn)換成代碼。編譯器的效率:編譯器應(yīng)生成效率高的代碼源代碼的可移植性:語言的標(biāo)準(zhǔn)化有助于提高程序代碼的可移植性,源程序中應(yīng)盡量不用標(biāo)準(zhǔn)文本以外的語句。17復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)將設(shè)計(jì)翻譯復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)配套的開發(fā)工具:CASE工具可減少編碼時(shí)間,提高代碼質(zhì)量。盡可能使用工具和程序設(shè)計(jì)支撐環(huán)境??蓮?fù)用性:指編程語言能否提供可復(fù)用的軟件成分,復(fù)用時(shí)需要修改調(diào)整的內(nèi)容多少可維護(hù)性:包括可理解性、可測(cè)試性、可修改性。源程序的可讀性和文檔化特性是影響可維護(hù)性的重要因素。18復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)配套的開發(fā)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)應(yīng)用特性不同的程序設(shè)計(jì)語言滿足不同的技術(shù)特性,可以對(duì)應(yīng)于不同的應(yīng)用。例如Prolog語言適用于人工智能領(lǐng)域、SQL語言適用于關(guān)系數(shù)據(jù)庫。語言的技術(shù)特性對(duì)軟件工程各階段有一定的影響,特別是確定了軟件需求之后,程序設(shè)計(jì)語言的特性就很重要了,要根據(jù)不同項(xiàng)目的特性選擇相應(yīng)特性的語言。19復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)應(yīng)用特性1復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的發(fā)展和分類程序設(shè)計(jì)語言的分類按語言級(jí)別:低級(jí)語言和高級(jí)語言;按應(yīng)用范圍:通用語言和專用語言;按用戶要求:過程式語言和非過程式語言;按語言所含的成分:順序語言、并發(fā)語言和分布式語言20復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的發(fā)展史第一代語言:機(jī)器語言和匯編語言第二代語言:早期的高級(jí)語言,如BASIC,F(xiàn)ORTRAN,COBOL等第三代語言:具有很強(qiáng)的數(shù)據(jù)結(jié)構(gòu)和過程描述能力,支持結(jié)構(gòu)化編程,如Pascal,Modula,C,Ada等第四代語言(4GL):這類語言出現(xiàn)于七十年代,其目的是為了提高程序開發(fā)速度,以及讓非專業(yè)用戶能直接編制計(jì)算機(jī)程序21復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)第四代語言的特點(diǎn):對(duì)用戶友善,一般用類自然語言、圖形或表格等描述方式,普通用戶很容易掌握多數(shù)與數(shù)據(jù)庫系統(tǒng)相結(jié)合,可直接對(duì)數(shù)據(jù)庫進(jìn)行操作對(duì)許多應(yīng)用功能均有默認(rèn)的假設(shè),用戶不必詳細(xì)說明每一件事情的做法程序碼長(zhǎng)度及獲得結(jié)果的時(shí)間與使用COBOL語言相比約少一個(gè)數(shù)量級(jí)支持結(jié)構(gòu)化編程,易于理解和維護(hù)22復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)第四代語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
目前,第四代語言的種類繁多,尚無標(biāo)準(zhǔn),在語法和能力上有很大差異,其中一些支持非過程式編程,更多的是既含有非過程語句,也含有過程語句。典型的4GL有:數(shù)據(jù)庫查詢語言、報(bào)表生成程序、應(yīng)用生成程序、電子表格、圖形語言等。多數(shù)4GL是面向領(lǐng)域的,很少是通用的。23復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)目前復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
自然語言最理想的是可以使用自然語言(如英語、法語或漢語),使計(jì)算機(jī)能理解并立即執(zhí)行請(qǐng)求。但迄今為止,自然語言理解仍然是計(jì)算機(jī)科學(xué)研究中的一個(gè)難點(diǎn),盡管在實(shí)驗(yàn)室的研究中取得了一定的成果,但在現(xiàn)實(shí)中的應(yīng)用仍然是相當(dāng)有限的。
24復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的選擇為一個(gè)特定的開發(fā)項(xiàng)目選擇編程語言時(shí),通常要考慮如下因素:應(yīng)用領(lǐng)域算法和計(jì)算復(fù)雜性軟件運(yùn)行環(huán)境用戶需求,特別是性能需求數(shù)據(jù)結(jié)構(gòu)的復(fù)雜性軟件開發(fā)人員的知識(shí)水平可用的編譯器與交叉編譯器25復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)項(xiàng)目所屬的應(yīng)用領(lǐng)域常常是首要的標(biāo)準(zhǔn)COBOL適用于商業(yè)領(lǐng)域FORTRAN適用于工程和科學(xué)計(jì)算領(lǐng)域Prolog、Lisp適用于人工智能領(lǐng)域Smalltalk、C++適用于OO系統(tǒng)的開發(fā)有些語言適用于多個(gè)應(yīng)用領(lǐng)域,如C若有多種語言都適合于某項(xiàng)目的開發(fā)時(shí),也可考慮選擇開發(fā)人員比較熟悉的語言26復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)項(xiàng)目所屬的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)選擇高級(jí)語言還是低級(jí)語言優(yōu)先選擇高級(jí)語言開發(fā)和維護(hù)高級(jí)語言程序比開發(fā)和維護(hù)低級(jí)語言程序容易得多必要時(shí)使用低級(jí)語言高級(jí)語言程序經(jīng)編譯后所產(chǎn)生的目標(biāo)程序的功效要比完成相同功能的低級(jí)語言程序低得多,所以在有些情況下會(huì)部分或全部使用低級(jí)語言27復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)選擇高級(jí)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
使用低級(jí)語言的情況:對(duì)運(yùn)行時(shí)間和存儲(chǔ)空間有過高要求的項(xiàng)目,如電子筆記本中的軟件在某些不能提供高級(jí)語言編譯程序的計(jì)算機(jī)上開發(fā)程序,如單片機(jī)上的軟件大型系統(tǒng)中對(duì)系統(tǒng)執(zhí)行時(shí)間起關(guān)鍵作用的模塊28復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格29復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)風(fēng)格編程的依據(jù)是詳細(xì)設(shè)計(jì)的結(jié)果,因此程序的質(zhì)量主要取決于設(shè)計(jì),但編程的質(zhì)量也在很大程度上影響著程序的質(zhì)量編程風(fēng)格主要包括:源程序中的內(nèi)部文檔數(shù)據(jù)說明語句構(gòu)造輸入/輸出30復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)風(fēng)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)源程序文檔化在源程序中可包含一些內(nèi)部文檔,以幫助閱讀和理解源程序在源程序中的內(nèi)部文檔主要包括:標(biāo)識(shí)符的命名注解程序的視覺組織31復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)源程序文檔復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)標(biāo)識(shí)符的命名選擇含義明確的名字,使其能正確提示標(biāo)識(shí)符所代表的實(shí)體例如,表示總量的變量名用Total,表示平均值的用Average等名字不要太長(zhǎng),太長(zhǎng)會(huì)增加打字量,且易出錯(cuò)。必要時(shí)可使用縮寫不用相似的名字,相似的名字容易混淆,不易發(fā)現(xiàn)錯(cuò)誤如cm,cn,cmn,cnm,cnn,cmm32復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)標(biāo)識(shí)符的命復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不用關(guān)鍵字作標(biāo)識(shí)符同一個(gè)名字不要有多個(gè)含義名字中避免使用易混淆的字符。如數(shù)字0與字母O;數(shù)字1與字母I或l;數(shù)字2與字母z等33復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不用關(guān)鍵字復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序的注釋程序中的注解用來幫助人們理解程序,決不是可有可無的一些正規(guī)的程序文本中,注解行的數(shù)量約占整個(gè)源程序的1/3到1/2,甚至更多注解分為序言性注解和功能性注解34復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序的注釋復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常置于每個(gè)程序模塊的開頭部分,主要描述:模塊的功能模塊的接口:包括調(diào)用格式、參數(shù)的解釋、該模塊需要調(diào)用的其它子模塊名重要的局部變量:包括用途、約束和限制條件開發(fā)歷史:包括模塊的設(shè)計(jì)者、評(píng)審者、評(píng)審日期、修改日期以及對(duì)修改的描述序言性注釋35復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常置于每復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常嵌在源程序體內(nèi),主要描述程序段的功能。書寫功能性注解時(shí)應(yīng)注意的問題:注解要正確,錯(cuò)誤的注解比沒有注解更壞;為程序段作注解,而不是為每一個(gè)語句作注解;用縮進(jìn)和空行,使程序與注釋容易區(qū)分;注解應(yīng)提供一些從程序本身難以得到的信息,而不是語句的重復(fù)。功能性注釋36復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常嵌在源復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)例如,下面的模塊級(jí)注釋描述了公共的和私有的過程(在類模塊中稱為“方法”)、屬性及其數(shù)據(jù)類型,以及如何將該類作為對(duì)象來使用的有關(guān)信息:公共方法:
MailAddRecipient(strNameAsString,OptionalfTypeAsBoolean)strName://要加入到郵件中的收件人名稱。
fType:OutlookMailItemType//屬性設(shè)置。
SendMail(OptionalblnShowMailFirstAsBoolean)blnShowMailFirst://發(fā)送前是否顯示Outlook郵件信息。如果不能解析收件人的地址,讓代碼將它設(shè)置為True。
私有方法:
InitializeOutlook()CreateMail()
公共屬性:
MailSubject:(Writeonly,String)MailMessage:(Writeonly,String)MailAttachments:(Writeonly,String)37復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)例如,下面復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通過在程序中添加一些空格、空行和縮進(jìn)等技巧,幫助人們從視覺上看清程序的結(jié)構(gòu)例如,通過縮進(jìn)技巧可清晰地觀察到程序的嵌套層次,同時(shí)還容易發(fā)現(xiàn)諸如“遺漏end”那樣的錯(cuò)誤視覺組織38復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通過在程序復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
IF(…)THEN
IF(…)THEN
……
ELSE
……
ENDIF
……
ELSE
……
ENDIF39復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)IF(復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然的程序段之間可用空行隔開可通過添加空格使語句成分清晰,如
(A<-17)ANDNOT(B<=49)ORC
可寫成
(A<-17)ANDNOT(B<=49)ORC也可以通過添加括號(hào)突出運(yùn)算的優(yōu)先級(jí),避免發(fā)生運(yùn)算的錯(cuò)誤,如
a**(b**c)40復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然的程序復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)放置大括號(hào)一般首選的方法是K&R方法:把左括號(hào)放在行尾,右括號(hào)放在行首。如:if
(X)
{Y}定義函數(shù)時(shí)應(yīng)當(dāng)把左右括號(hào)都放在行首,如:int
F(int
x){//}注意,右括號(hào)所在的行不應(yīng)當(dāng)有其它語句,除非跟隨著一個(gè)條件判斷。也就是do-while語句中的“while”和if-else語句中的“else”。例如:do
{body
of
do-loop}
while
(condition);if
(x
==
y)
{…
}
else
if
(x
>
y)
{...}
else
{…
}41復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)放置大括號(hào)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明為了使程序中數(shù)據(jù)說明更易于理解和維護(hù),可采用以下風(fēng)格:數(shù)據(jù)說明的次序應(yīng)當(dāng)規(guī)范化說明語句中變量安排有序化使用注解說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)42復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明為復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明的次序應(yīng)當(dāng)規(guī)范化數(shù)據(jù)說明次序規(guī)范化,使數(shù)據(jù)屬性容易查找,也有利于測(cè)試,排錯(cuò)和維護(hù)原則上,數(shù)據(jù)說明的次序與語法無關(guān),其次序是任意的。但出于閱讀、理解和維護(hù)的需要,最好使其規(guī)范化,使說明的先后次序固定43復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)說明語句中變量安排有序化當(dāng)多個(gè)變量名在一個(gè)說明語句中說明時(shí),可以將這些變量按字母的順序排列,以便于查找44復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)說明語句中復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)使用注釋說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)如果設(shè)計(jì)了一個(gè)復(fù)雜的數(shù)據(jù)結(jié)構(gòu),應(yīng)當(dāng)使用注釋來說明在程序?qū)崿F(xiàn)時(shí)這個(gè)數(shù)據(jù)結(jié)構(gòu)的固有特點(diǎn)例如用戶自定義的數(shù)據(jù)類型,應(yīng)當(dāng)在注釋中做必要的補(bǔ)充說明45復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)使用注釋說復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語句構(gòu)造編碼階段的主要任務(wù)就是書寫程序語句。有關(guān)書寫語句的原則有幾十種,總起來說,希望每條語句盡可能簡(jiǎn)單明了,能直截了當(dāng)?shù)胤从吵绦騿T的意圖,不能為了片面追求效率而使語句復(fù)雜化。常用的規(guī)則如下:46復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語句構(gòu)造編復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)1.在一行內(nèi)只寫一條語句在一行內(nèi)只寫一條語句,并且采取適當(dāng)添加空格的辦法,使程序的邏輯和功能變得更加明確。許多程序設(shè)計(jì)語言允許在一行內(nèi)寫多個(gè)語句。但這種方式會(huì)使程序可讀性變差。因而不可取。47復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)1.在一復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)2.程序編寫首先應(yīng)當(dāng)考慮清晰性程序編寫首先應(yīng)當(dāng)考慮清晰性,不要刻意追求技巧性,使程序編寫得過于緊湊。例如,有一個(gè)用C語句寫出的程序段:
A[I]=A[I]+A[T];
A[T]=A[I]-A[T];
A[I]=A[I]-A[T];48復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)2.程序編復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
此段程序可能不易看懂,有時(shí)還需用實(shí)際數(shù)據(jù)試驗(yàn)一下。實(shí)際上,這段程序的功能就是交換A[I]和A[T]中的內(nèi)容。目的是為了節(jié)省一個(gè)工作單元。如果改一下:
WORK=A[T];
A[T]=A[I];
A[I]=WORK;
就能讓讀者一目了然了。49復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)3.程序要能直截了當(dāng)?shù)卣f明程序員的用意。程序編寫得要簡(jiǎn)單,寫清楚,直截了當(dāng)?shù)卣f明程序員的用意。例如,
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
V[i][j]=(i/j)*(j/i)
除法運(yùn)算(/)在除數(shù)和被除數(shù)都是整型量時(shí),其結(jié)果只取整數(shù)部分,而得到整型量。50復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)3.程序要復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
當(dāng)i<j時(shí),i/j=0
當(dāng)j<i時(shí),j/i=0
得到的數(shù)組當(dāng)i≠j時(shí)
V[i][j]=(i/j)*(j/i)=0當(dāng)i=j(luò)時(shí)
V[i][j]=(i/j)*(j/i)=1這樣得到的結(jié)果V是一個(gè)單位矩陣。51復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)寫成以下的形式,就能讓讀者直接了解程序編寫者的意圖。
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
if(i==j)
V[i][j]=1.0;
ELSE
V[i][j]=0.0;52復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)寫成以下的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)4.其他常用規(guī)則讓編譯程序做簡(jiǎn)單的優(yōu)化。盡可能使用庫函數(shù)避免不必要的轉(zhuǎn)移。盡量只采用三種基本的控制結(jié)構(gòu)來編寫程序。除順序結(jié)構(gòu)外,使用if-then-else來實(shí)現(xiàn)選擇結(jié)構(gòu);使用do-until或do-while來實(shí)現(xiàn)循環(huán)結(jié)構(gòu)。53復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)4.其他常復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)輸入和輸出輸入和輸出信息是與用戶的使用直接相關(guān)的。輸入和輸出的方式和格式應(yīng)當(dāng)盡可能方便用戶的使用。一定要避免因設(shè)計(jì)不當(dāng)給用戶帶來的麻煩因此,在軟件需求分析階段和設(shè)計(jì)階段,就應(yīng)基本確定輸入和輸出的風(fēng)格。系統(tǒng)能否被用戶接受,有時(shí)就取決于輸入和輸出的風(fēng)格54復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)輸入和輸出復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不論是批處理的輸入/輸出方式,還是交互式的輸入/輸出方式,在設(shè)計(jì)和編碼時(shí)都應(yīng)考慮下列原則:1.
對(duì)所有的輸入數(shù)據(jù)都要進(jìn)行檢驗(yàn),識(shí)別錯(cuò)誤的輸入,以保證每個(gè)數(shù)據(jù)的有效性;2.
檢查輸入項(xiàng)的各種重要組合的合理性,必要時(shí)報(bào)告輸入狀態(tài)信息;3.
使得輸入的步驟和操作盡可能簡(jiǎn)單,并保持簡(jiǎn)單的輸入格式;55復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不論是批處復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
4.
輸入數(shù)據(jù)時(shí),應(yīng)允許使用自由格式輸入;
5.
應(yīng)允許缺省值;
6.
輸入一批數(shù)據(jù)時(shí),最好使用輸入結(jié)束標(biāo)志,而不要由用戶指定輸入數(shù)據(jù)數(shù)目;
7.
在交互式輸入輸入時(shí),要在屏幕上使用提示符明確提示交互輸入的請(qǐng)求,指明可使用選擇項(xiàng)的種類和取值范圍。同時(shí),在數(shù)據(jù)輸入的過程中和輸入結(jié)束時(shí),也要在屏幕上給出狀態(tài)信息;56復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)4.輸復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)8.
當(dāng)程序設(shè)計(jì)語言對(duì)輸入/輸出格式有嚴(yán)格要求時(shí),應(yīng)保持輸入格式與輸入語句的要求的一致性;9.
給所有的輸出加注解,并設(shè)計(jì)良好的輸出報(bào)表。
輸入/輸出風(fēng)格還受到許多其它因素的影響。如輸入/輸出設(shè)備(例如終端的類型,圖形設(shè)備,數(shù)字化轉(zhuǎn)換設(shè)備等)、用戶的熟練程度、以及通信環(huán)境等。
57復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)8.當(dāng)程軟件工程第12章程序設(shè)計(jì)語言和編碼軟件工程第12章程序設(shè)計(jì)語言和編碼復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)編碼階段的任務(wù)是根據(jù)詳細(xì)設(shè)計(jì)說明書編寫程序程序設(shè)計(jì)語言的特性和程序設(shè)計(jì)風(fēng)格會(huì)深刻地影響軟件的質(zhì)量和可維護(hù)性為了保證程序編碼的質(zhì)量,程序員必須深刻理解、熟練掌握并正確地運(yùn)用程序設(shè)計(jì)語言的特性此外,還要求源程序具有良好的結(jié)構(gòu)性和良好的程序設(shè)計(jì)風(fēng)格59復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)編碼階段的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格60復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格61復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本概念程序設(shè)計(jì)語言是指用于書寫計(jì)算機(jī)程序的語言,它是一種實(shí)現(xiàn)性的軟件語言語法(syntax)表示程序的結(jié)構(gòu)或形式,即表示構(gòu)成語言的各個(gè)記號(hào)之間的組合規(guī)則,但不涉及這些記號(hào)固有的以及和使用情景有關(guān)的含義如C語言中for語句的構(gòu)成規(guī)則是:
for(表達(dá)式1;表達(dá)式2;表達(dá)式3)語句
語法中不涉及這些記號(hào)的含義,也不涉及使用情景62復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本概念程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語義(semantic)表示語言成分的固有含義,即表示按照各種方法所表示的各個(gè)記號(hào)的特定含義,但不涉及到使用者。
如上述for語句中:表達(dá)式1表示循環(huán)初值;表達(dá)式2表示循環(huán)條件;表達(dá)式3表示循環(huán)的增量;語句為循環(huán)體。整個(gè)語句的語義是:(1)計(jì)算表達(dá)式1(2)計(jì)算表達(dá)式2,若計(jì)算結(jié)果為0,則終止循環(huán);否則轉(zhuǎn)(3)(3)執(zhí)行循環(huán)體(4)計(jì)算表達(dá)式3(5)轉(zhuǎn)向(2)63復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語義(se復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語用(pragmatic)表示程序與使用情景有關(guān)的含義。語用是語言成分在程序特定執(zhí)行中的實(shí)際效用如:語言是否允許遞歸?是否要規(guī)定遞歸層數(shù)的上界?這種上界如何確定?這些都屬于語用上的問題。64復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語用(pr復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的基本成分程序設(shè)計(jì)語言基本成份可歸納為四種:數(shù)據(jù)成分、運(yùn)算成分、控制成分、傳輸成分?jǐn)?shù)據(jù)成分:指明該語言能接受的數(shù)據(jù),用以描述程序中的數(shù)據(jù)。如各種類型的變量、數(shù)組、指針、記錄等。作為程序操作的對(duì)象,具有名稱、類型和作用域等特征。使用前要對(duì)數(shù)據(jù)的這些特征加以說明。數(shù)據(jù)名稱由用戶通過標(biāo)識(shí)符命名,類型說明數(shù)據(jù)需占用存儲(chǔ)單元的多少和存放形式,作用域說明數(shù)據(jù)可以使用的范圍。65復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)以C語言為例,其數(shù)據(jù)構(gòu)造方式可分為基本類型和派生類型
66復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)以C語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)運(yùn)算成分:指明該語言允許執(zhí)行的運(yùn)算,用以描述程序中所包含的運(yùn)算。如+、-、*、/等。控制成分:指明該語言允許的控制結(jié)構(gòu),用以表達(dá)程序中的控制構(gòu)造?;镜目刂瞥煞职ǎ喉樞蚪Y(jié)構(gòu)、條件選擇結(jié)構(gòu)和重復(fù)結(jié)構(gòu)。如下頁圖67復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)運(yùn)算成分:復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本程序控制結(jié)構(gòu)68復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)基本程序控復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)傳輸成分:它指明該語言允許的數(shù)據(jù)傳輸方式,在程序中可用以表達(dá)程序中數(shù)據(jù)的傳輸。例如:TurboC語言標(biāo)準(zhǔn)庫提供了兩個(gè)控制臺(tái)格式化輸入、輸出函數(shù)printf()和scanf(),這兩個(gè)函數(shù)可以在標(biāo)準(zhǔn)輸入輸出設(shè)備上以各種不同的格式讀寫數(shù)據(jù)。Printf()函數(shù)用來向標(biāo)準(zhǔn)輸出設(shè)備(屏幕)寫數(shù)據(jù),scanf()函數(shù)用來從標(biāo)準(zhǔn)輸入設(shè)備(鍵盤)上讀數(shù)據(jù)。
69復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)傳輸成分:復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的特性心理特性從設(shè)計(jì)到編碼的轉(zhuǎn)換基本上是人的活動(dòng),因此,語言的性能對(duì)程序員的心理影響將對(duì)轉(zhuǎn)換產(chǎn)生重大影響在維持現(xiàn)有機(jī)器的效率、容量和其它硬件限制條件的前提下,程序員總希望選擇簡(jiǎn)單易學(xué)、使用方便的語言,以減少程序出錯(cuò)率,提高軟件可靠性,從而提高用戶對(duì)軟件質(zhì)量的可信度70復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
在維持現(xiàn)有機(jī)器的效率、容量和其它硬件限制條件的前提下,程序員總希望選擇簡(jiǎn)單易學(xué)、使用方便的語言,以減少程序出錯(cuò)率,提高軟件可靠性,從而提高用戶對(duì)軟件質(zhì)量的可信度。
影響響程序員心理的語言特性有:一致性:指語言采用的標(biāo)記法(使用的符號(hào))協(xié)調(diào)一致的程度。如,一符多用的標(biāo)記法容易導(dǎo)致錯(cuò)誤。71復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)在維復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)二義性:對(duì)語句不同理解所產(chǎn)生的二義性將導(dǎo)致程序員對(duì)程序理解的混亂。如,
ifthenifthenelsex:=a**b**c緊致性(compactness):指程序員必須記憶的與編碼有關(guān)的信息總量。線性:人們所習(xí)慣的理解程序的次序,程序中多層的嵌套分支和循環(huán)、隨意的GOTO語句會(huì)破壞程序的線性次序。72復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)二義性:對(duì)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)工程特性程序設(shè)計(jì)語言的特性影響人們思考程序的方式,從而也限制了人們與計(jì)算機(jī)進(jìn)行通信的方式。為滿足軟件工程的需要,程序設(shè)計(jì)語言還應(yīng)該考慮:將設(shè)計(jì)翻譯成代碼的便利程度、編譯器的效率、源代碼的可移植性、配套的開發(fā)工具、軟件的可復(fù)用性和可維護(hù)性。73復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)工程特性1復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)將設(shè)計(jì)翻譯成代碼的便利程度:語言若直接支持結(jié)構(gòu)化部件、復(fù)雜的數(shù)據(jù)結(jié)構(gòu)、特殊I/O處理、按位操作和OO方法,則便于將設(shè)計(jì)轉(zhuǎn)換成代碼。編譯器的效率:編譯器應(yīng)生成效率高的代碼源代碼的可移植性:語言的標(biāo)準(zhǔn)化有助于提高程序代碼的可移植性,源程序中應(yīng)盡量不用標(biāo)準(zhǔn)文本以外的語句。74復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)將設(shè)計(jì)翻譯復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)配套的開發(fā)工具:CASE工具可減少編碼時(shí)間,提高代碼質(zhì)量。盡可能使用工具和程序設(shè)計(jì)支撐環(huán)境??蓮?fù)用性:指編程語言能否提供可復(fù)用的軟件成分,復(fù)用時(shí)需要修改調(diào)整的內(nèi)容多少可維護(hù)性:包括可理解性、可測(cè)試性、可修改性。源程序的可讀性和文檔化特性是影響可維護(hù)性的重要因素。75復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)配套的開發(fā)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)應(yīng)用特性不同的程序設(shè)計(jì)語言滿足不同的技術(shù)特性,可以對(duì)應(yīng)于不同的應(yīng)用。例如Prolog語言適用于人工智能領(lǐng)域、SQL語言適用于關(guān)系數(shù)據(jù)庫。語言的技術(shù)特性對(duì)軟件工程各階段有一定的影響,特別是確定了軟件需求之后,程序設(shè)計(jì)語言的特性就很重要了,要根據(jù)不同項(xiàng)目的特性選擇相應(yīng)特性的語言。76復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)應(yīng)用特性1復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的發(fā)展和分類程序設(shè)計(jì)語言的分類按語言級(jí)別:低級(jí)語言和高級(jí)語言;按應(yīng)用范圍:通用語言和專用語言;按用戶要求:過程式語言和非過程式語言;按語言所含的成分:順序語言、并發(fā)語言和分布式語言77復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的發(fā)展史第一代語言:機(jī)器語言和匯編語言第二代語言:早期的高級(jí)語言,如BASIC,F(xiàn)ORTRAN,COBOL等第三代語言:具有很強(qiáng)的數(shù)據(jù)結(jié)構(gòu)和過程描述能力,支持結(jié)構(gòu)化編程,如Pascal,Modula,C,Ada等第四代語言(4GL):這類語言出現(xiàn)于七十年代,其目的是為了提高程序開發(fā)速度,以及讓非專業(yè)用戶能直接編制計(jì)算機(jī)程序78復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)第四代語言的特點(diǎn):對(duì)用戶友善,一般用類自然語言、圖形或表格等描述方式,普通用戶很容易掌握多數(shù)與數(shù)據(jù)庫系統(tǒng)相結(jié)合,可直接對(duì)數(shù)據(jù)庫進(jìn)行操作對(duì)許多應(yīng)用功能均有默認(rèn)的假設(shè),用戶不必詳細(xì)說明每一件事情的做法程序碼長(zhǎng)度及獲得結(jié)果的時(shí)間與使用COBOL語言相比約少一個(gè)數(shù)量級(jí)支持結(jié)構(gòu)化編程,易于理解和維護(hù)79復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)第四代語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
目前,第四代語言的種類繁多,尚無標(biāo)準(zhǔn),在語法和能力上有很大差異,其中一些支持非過程式編程,更多的是既含有非過程語句,也含有過程語句。典型的4GL有:數(shù)據(jù)庫查詢語言、報(bào)表生成程序、應(yīng)用生成程序、電子表格、圖形語言等。多數(shù)4GL是面向領(lǐng)域的,很少是通用的。80復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)目前復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
自然語言最理想的是可以使用自然語言(如英語、法語或漢語),使計(jì)算機(jī)能理解并立即執(zhí)行請(qǐng)求。但迄今為止,自然語言理解仍然是計(jì)算機(jī)科學(xué)研究中的一個(gè)難點(diǎn),盡管在實(shí)驗(yàn)室的研究中取得了一定的成果,但在現(xiàn)實(shí)中的應(yīng)用仍然是相當(dāng)有限的。
81復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然語言復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語言的選擇為一個(gè)特定的開發(fā)項(xiàng)目選擇編程語言時(shí),通常要考慮如下因素:應(yīng)用領(lǐng)域算法和計(jì)算復(fù)雜性軟件運(yùn)行環(huán)境用戶需求,特別是性能需求數(shù)據(jù)結(jié)構(gòu)的復(fù)雜性軟件開發(fā)人員的知識(shí)水平可用的編譯器與交叉編譯器82復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)項(xiàng)目所屬的應(yīng)用領(lǐng)域常常是首要的標(biāo)準(zhǔn)COBOL適用于商業(yè)領(lǐng)域FORTRAN適用于工程和科學(xué)計(jì)算領(lǐng)域Prolog、Lisp適用于人工智能領(lǐng)域Smalltalk、C++適用于OO系統(tǒng)的開發(fā)有些語言適用于多個(gè)應(yīng)用領(lǐng)域,如C若有多種語言都適合于某項(xiàng)目的開發(fā)時(shí),也可考慮選擇開發(fā)人員比較熟悉的語言83復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)項(xiàng)目所屬的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)選擇高級(jí)語言還是低級(jí)語言優(yōu)先選擇高級(jí)語言開發(fā)和維護(hù)高級(jí)語言程序比開發(fā)和維護(hù)低級(jí)語言程序容易得多必要時(shí)使用低級(jí)語言高級(jí)語言程序經(jīng)編譯后所產(chǎn)生的目標(biāo)程序的功效要比完成相同功能的低級(jí)語言程序低得多,所以在有些情況下會(huì)部分或全部使用低級(jí)語言84復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)選擇高級(jí)語復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
使用低級(jí)語言的情況:對(duì)運(yùn)行時(shí)間和存儲(chǔ)空間有過高要求的項(xiàng)目,如電子筆記本中的軟件在某些不能提供高級(jí)語言編譯程序的計(jì)算機(jī)上開發(fā)程序,如單片機(jī)上的軟件大型系統(tǒng)中對(duì)系統(tǒng)執(zhí)行時(shí)間起關(guān)鍵作用的模塊85復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程序設(shè)計(jì)語言程序設(shè)計(jì)風(fēng)格86復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)內(nèi)容摘要程復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)風(fēng)格編程的依據(jù)是詳細(xì)設(shè)計(jì)的結(jié)果,因此程序的質(zhì)量主要取決于設(shè)計(jì),但編程的質(zhì)量也在很大程度上影響著程序的質(zhì)量編程風(fēng)格主要包括:源程序中的內(nèi)部文檔數(shù)據(jù)說明語句構(gòu)造輸入/輸出87復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序設(shè)計(jì)風(fēng)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)源程序文檔化在源程序中可包含一些內(nèi)部文檔,以幫助閱讀和理解源程序在源程序中的內(nèi)部文檔主要包括:標(biāo)識(shí)符的命名注解程序的視覺組織88復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)源程序文檔復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)標(biāo)識(shí)符的命名選擇含義明確的名字,使其能正確提示標(biāo)識(shí)符所代表的實(shí)體例如,表示總量的變量名用Total,表示平均值的用Average等名字不要太長(zhǎng),太長(zhǎng)會(huì)增加打字量,且易出錯(cuò)。必要時(shí)可使用縮寫不用相似的名字,相似的名字容易混淆,不易發(fā)現(xiàn)錯(cuò)誤如cm,cn,cmn,cnm,cnn,cmm89復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)標(biāo)識(shí)符的命復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不用關(guān)鍵字作標(biāo)識(shí)符同一個(gè)名字不要有多個(gè)含義名字中避免使用易混淆的字符。如數(shù)字0與字母O;數(shù)字1與字母I或l;數(shù)字2與字母z等90復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)不用關(guān)鍵字復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序的注釋程序中的注解用來幫助人們理解程序,決不是可有可無的一些正規(guī)的程序文本中,注解行的數(shù)量約占整個(gè)源程序的1/3到1/2,甚至更多注解分為序言性注解和功能性注解91復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)程序的注釋復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常置于每個(gè)程序模塊的開頭部分,主要描述:模塊的功能模塊的接口:包括調(diào)用格式、參數(shù)的解釋、該模塊需要調(diào)用的其它子模塊名重要的局部變量:包括用途、約束和限制條件開發(fā)歷史:包括模塊的設(shè)計(jì)者、評(píng)審者、評(píng)審日期、修改日期以及對(duì)修改的描述序言性注釋92復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常置于每復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常嵌在源程序體內(nèi),主要描述程序段的功能。書寫功能性注解時(shí)應(yīng)注意的問題:注解要正確,錯(cuò)誤的注解比沒有注解更壞;為程序段作注解,而不是為每一個(gè)語句作注解;用縮進(jìn)和空行,使程序與注釋容易區(qū)分;注解應(yīng)提供一些從程序本身難以得到的信息,而不是語句的重復(fù)。功能性注釋93復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通常嵌在源復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)例如,下面的模塊級(jí)注釋描述了公共的和私有的過程(在類模塊中稱為“方法”)、屬性及其數(shù)據(jù)類型,以及如何將該類作為對(duì)象來使用的有關(guān)信息:公共方法:
MailAddRecipient(strNameAsString,OptionalfTypeAsBoolean)strName://要加入到郵件中的收件人名稱。
fType:OutlookMailItemType//屬性設(shè)置。
SendMail(OptionalblnShowMailFirstAsBoolean)blnShowMailFirst://發(fā)送前是否顯示Outlook郵件信息。如果不能解析收件人的地址,讓代碼將它設(shè)置為True。
私有方法:
InitializeOutlook()CreateMail()
公共屬性:
MailSubject:(Writeonly,String)MailMessage:(Writeonly,String)MailAttachments:(Writeonly,String)94復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)例如,下面復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通過在程序中添加一些空格、空行和縮進(jìn)等技巧,幫助人們從視覺上看清程序的結(jié)構(gòu)例如,通過縮進(jìn)技巧可清晰地觀察到程序的嵌套層次,同時(shí)還容易發(fā)現(xiàn)諸如“遺漏end”那樣的錯(cuò)誤視覺組織95復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)通過在程序復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)
IF(…)THEN
IF(…)THEN
……
ELSE
……
ENDIF
……
ELSE
……
ENDIF96復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)IF(復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然的程序段之間可用空行隔開可通過添加空格使語句成分清晰,如
(A<-17)ANDNOT(B<=49)ORC
可寫成
(A<-17)ANDNOT(B<=49)ORC也可以通過添加括號(hào)突出運(yùn)算的優(yōu)先級(jí),避免發(fā)生運(yùn)算的錯(cuò)誤,如
a**(b**c)97復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)自然的程序復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)放置大括號(hào)一般首選的方法是K&R方法:把左括號(hào)放在行尾,右括號(hào)放在行首。如:if
(X)
{Y}定義函數(shù)時(shí)應(yīng)當(dāng)把左右括號(hào)都放在行首,如:int
F(int
x){//}注意,右括號(hào)所在的行不應(yīng)當(dāng)有其它語句,除非跟隨著一個(gè)條件判斷。也就是do-while語句中的“while”和if-else語句中的“else”。例如:do
{body
of
do-loop}
while
(condition);if
(x
==
y)
{…
}
else
if
(x
>
y)
{...}
else
{…
}98復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)放置大括號(hào)復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明為了使程序中數(shù)據(jù)說明更易于理解和維護(hù),可采用以下風(fēng)格:數(shù)據(jù)說明的次序應(yīng)當(dāng)規(guī)范化說明語句中變量安排有序化使用注解說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)99復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明為復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明的次序應(yīng)當(dāng)規(guī)范化數(shù)據(jù)說明次序規(guī)范化,使數(shù)據(jù)屬性容易查找,也有利于測(cè)試,排錯(cuò)和維護(hù)原則上,數(shù)據(jù)說明的次序與語法無關(guān),其次序是任意的。但出于閱讀、理解和維護(hù)的需要,最好使其規(guī)范化,使說明的先后次序固定100復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)數(shù)據(jù)說明的復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)說明語句中變量安排有序化當(dāng)多個(gè)變量名在一個(gè)說明語句中說明時(shí),可以將這些變量按字母的順序排列,以便于查找101復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)說明語句中復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)使用注釋說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)如果設(shè)計(jì)了一個(gè)復(fù)雜的數(shù)據(jù)結(jié)構(gòu),應(yīng)當(dāng)使用注釋來說明在程序?qū)崿F(xiàn)時(shí)這個(gè)數(shù)據(jù)結(jié)構(gòu)的固有特點(diǎn)例如用戶自定義的數(shù)據(jù)類型,應(yīng)當(dāng)在注釋中做必要的補(bǔ)充說明102復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)使用注釋說復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語句構(gòu)造編碼階段的主要任務(wù)就是書寫程序語句。有關(guān)書寫語句的原則有幾十種,總起來說,希望每條語句盡可能簡(jiǎn)單明了,能直截了當(dāng)?shù)胤从吵绦騿T的意圖,不能為了片面追求效率而使語句復(fù)雜化。常用的規(guī)則如下:103復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)語句構(gòu)造編復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)1.在一行內(nèi)只寫一條語句在一行內(nèi)只寫一條語句,并且采取適當(dāng)添加空格的辦法,使程序的邏輯和功能變得更加明確。許多程序設(shè)計(jì)語言允許在一行內(nèi)寫多個(gè)語句。但這種方式會(huì)使程序可讀性變差。因而不可取。104復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)1.在一復(fù)旦大學(xué)計(jì)算機(jī)科學(xué)技術(shù)學(xué)院軟件工程(第二版)2.
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年物聯(lián)網(wǎng)項(xiàng)目開發(fā)與合作合同
- 2025年度智能停車設(shè)施安裝合同3篇
- 鐵路電務(wù)知識(shí)培訓(xùn)課件
- 2025年度大棚蔬菜種植與農(nóng)業(yè)觀光旅游融合發(fā)展承包合同3篇
- 吉林省長(zhǎng)春市九臺(tái)區(qū)2024-2025學(xué)年七年級(jí)(上)期末語文試卷(含解析)
- 2024年電子商務(wù)平臺(tái)運(yùn)營(yíng)服務(wù)合同具體條款
- 2025離婚財(cái)產(chǎn)分割協(xié)議書范本撰寫與審查指南3篇
- 浙江師范大學(xué)《設(shè)備狀態(tài)監(jiān)測(cè)與故障診斷》2023-2024學(xué)年第一學(xué)期期末試卷
- 長(zhǎng)春師范大學(xué)《書法蒙刻》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025年度酒店餐飲管理咨詢合作協(xié)議3篇
- 安徽省合肥市包河區(qū)2023-2024學(xué)年九年級(jí)上學(xué)期期末化學(xué)試題
- 售樓部保安管理培訓(xùn)
- 2024年高壓電工證理論考試題庫(含答案)
- 倉(cāng)儲(chǔ)培訓(xùn)課件模板
- 2023-2024學(xué)年仁愛版七上期末考試英語(試題)
- 2024年醫(yī)院培訓(xùn)計(jì)劃
- GB/T 44914-2024和田玉分級(jí)
- 2023年湖南出版中南傳媒招聘筆試真題
- 2024年度企業(yè)入駐跨境電商孵化基地合作協(xié)議3篇
- 呼吸內(nèi)科臨床診療指南及操作規(guī)范
- 學(xué)生管理教育課件
評(píng)論
0/150
提交評(píng)論