版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
會計學(xué)1程序設(shè)計語言和編碼內(nèi)容摘要程序設(shè)計語言程序設(shè)計風(fēng)格第1頁/共60頁內(nèi)容摘要程序設(shè)計語言程序設(shè)計風(fēng)格第2頁/共60頁基本概念程序設(shè)計語言是指用于書寫計算機程序的語言,它是一種實現(xiàn)性的軟件語言語法(syntax)用來表示構(gòu)成語言的各個記號之間的組合規(guī)則,它是構(gòu)成語言結(jié)構(gòu)正確成分所需遵循的規(guī)則集合如C語言中for語句的構(gòu)成規(guī)則是:
for(表達式1;表達式2;表達式3)語句
語法中不涉及到這些記號的含義,也不涉及使用者第3頁/共60頁語義(semantic)用來表示按照各種表示方式所表示的各個記號的特定含義,但它不涉及到使用者。
如上述for語句中:表達式1表示循環(huán)初值;表達式2表示循環(huán)條件;表達式3表示循環(huán)的增量;語句為循環(huán)體。整個語句的語義是:(1)計算表達式1(2)計算表達式2,若計算結(jié)果為0,則終止循環(huán);否則轉(zhuǎn)(3)(3)執(zhí)行循環(huán)體(4)計算表達式3(5)轉(zhuǎn)向(2)第4頁/共60頁語用(pragmatic)用來表示構(gòu)成語言的各個記號和使用者的關(guān)系。如:語言是否允許遞歸?是否要規(guī)定遞歸層數(shù)的上界?這種上界如何確定?這些都屬于語用上的問題。第5頁/共60頁程序設(shè)計語言的基本成分程序設(shè)計語言基本成份可歸納為四種:數(shù)據(jù)成分、運算成分、控制成分、傳輸成分數(shù)據(jù)成分:它指明該語言能接受的數(shù)據(jù),用來描述程序中的數(shù)據(jù)。如各種類型的變量、數(shù)組、指針、記錄等。作為程序操作的對象,具有名稱、類型和作用域等特征。使用前要對數(shù)據(jù)的這些特征加以說明。數(shù)據(jù)名稱由用戶通過標識符命名,類型說明數(shù)據(jù)需占用存儲單元的多少和存放形式,作用域說明數(shù)據(jù)可以使用的范圍。第6頁/共60頁以C語言為例,其數(shù)據(jù)構(gòu)造方式可分為基本類型和派生類型
第7頁/共60頁運算成分:它指明該語言允許執(zhí)行的運算,用來描述程序中所需進行的運算。如+、-、*、/等??刂瞥煞郑核该髟撜Z言允許的控制結(jié)構(gòu),人們可利用這些控制成分來構(gòu)造程序中的控制邏輯?;镜目刂瞥煞职ǎ喉樞蚪Y(jié)構(gòu)、條件選擇結(jié)構(gòu)和重復(fù)結(jié)構(gòu)。如下頁圖第8頁/共60頁基本程序控制結(jié)構(gòu)第9頁/共60頁傳輸成分:它指明該語言允許的數(shù)據(jù)傳輸方式,在程序中可用它進行數(shù)據(jù)傳輸。例如:TurboC語言標準庫提供了兩個控制臺格式化輸入、輸出函數(shù)printf()和scanf(),這兩個函數(shù)可以在標準輸入輸出設(shè)備上以各種不同的格式讀寫數(shù)據(jù)。Printf()函數(shù)用來向標準輸出設(shè)備(屏幕)寫數(shù)據(jù),scanf()函數(shù)用來從標準輸入設(shè)備(鍵盤)上讀數(shù)據(jù)。
第10頁/共60頁程序設(shè)計語言的特性心理特性從設(shè)計到編碼的轉(zhuǎn)換基本上是人的活動,因此,語言的性能對程序員的心理影響將對轉(zhuǎn)換產(chǎn)生重大影響在維持現(xiàn)有機器的效率、容量和其它硬件限制條件的前提下,程序員總希望選擇簡單易學(xué)、使用方便的語言,以減少程序出錯率,提高軟件可靠性,從而提高用戶對軟件質(zhì)量的可信度第11頁/共60頁
影響程序員心理的語言特性有:一致性:指語言采用的標記法(使用的符號)協(xié)調(diào)一致的程度。如,一符多用的標記法容易導(dǎo)致錯誤。二義性:對語句不同理解所產(chǎn)生的二義性將導(dǎo)致程序員對程序理解的混亂。如,
ifthenifthenelsex:=a**b**c第12頁/共60頁緊致性(compactness):指程序員必須記憶的與編碼有關(guān)的信息總量。刻畫緊致性的指標有:對結(jié)構(gòu)化部件的支持程度,可用關(guān)鍵字和縮寫的種類,算術(shù)及邏輯操作符的數(shù)目,預(yù)定義函數(shù)的個數(shù)等。局部性:程序由模塊組成,應(yīng)采用高內(nèi)聚低耦合、模塊獨立、局部化等原則。線性:人們習(xí)慣于按邏輯上線性的次序理解程序,程序中大量的分支和循環(huán)、隨意的GOTO語句會破壞程序的線性,提倡結(jié)構(gòu)化程序設(shè)計。第13頁/共60頁傳統(tǒng)性:傳統(tǒng)性容易影響人們學(xué)習(xí)新語種的積極性第14頁/共60頁工程特性程序設(shè)計語言的特性影響人們思考程序的方式,從而也限制了人們與計算機進行通信的方式。為滿足軟件工程的需要,程序設(shè)計語言還應(yīng)該考慮:將設(shè)計翻譯成代碼的便利程度、編譯器的效率、源代碼的可移植性、配套的開發(fā)工具、軟件的可復(fù)用性和可維護性。第15頁/共60頁將設(shè)計翻譯成代碼的便利程度:語言若直接支持結(jié)構(gòu)化部件、復(fù)雜的數(shù)據(jù)結(jié)構(gòu)、特殊I/O處理、按位操作和OO方法,則便于將設(shè)計轉(zhuǎn)換成代碼。編譯器的效率:編譯器應(yīng)生成效率高的代碼源代碼的可移植性:語言的標準化有助于提高程序代碼的可移植性,源程序中應(yīng)盡量不用標準文本以外的語句。第16頁/共60頁配套的開發(fā)工具:CASE工具可減少編碼時間,提高代碼質(zhì)量。盡可能使用工具和程序設(shè)計支撐環(huán)境。可復(fù)用性:指編程語言能否提供可復(fù)用的軟件成分,復(fù)用時需要修改調(diào)整的內(nèi)容多少可維護性:包括可理解性、可測試性、可修改性。源程序的可讀性和文檔化特性是影響可維護性的重要因素。第17頁/共60頁應(yīng)用特性不同的程序設(shè)計語言滿足不同的技術(shù)特性,可以對應(yīng)于不同的應(yīng)用。例如Prolog語言適用于人工智能領(lǐng)域、SQL語言適用于關(guān)系數(shù)據(jù)庫。語言的技術(shù)特性對軟件工程各階段有一定的影響,特別是確定了軟件需求之后,程序設(shè)計語言的特性就很重要了,要根據(jù)不同項目的特性選擇相應(yīng)特性的語言。第18頁/共60頁程序設(shè)計語言的發(fā)展和分類程序設(shè)計語言的分類按語言級別:低級語言和高級語言;按應(yīng)用范圍:通用語言和專用語言;按用戶要求:過程式語言和非過程式語言;按語言所含的成分:順序語言、并發(fā)語言和分布式語言第19頁/共60頁程序設(shè)計語言的發(fā)展史第一代語言:機器語言和匯編語言第二代語言:早期的高級語言,如BASIC,F(xiàn)ORTRAN,COBOL等第三代語言:具有很強的數(shù)據(jù)結(jié)構(gòu)和過程描述能力,支持結(jié)構(gòu)化編程,如Pascal,Modula,C,Ada等第四代語言(4GL):這類語言出現(xiàn)于七十年代,其目的是為了提高程序開發(fā)速度,以及讓非專業(yè)用戶能直接編制計算機程序第20頁/共60頁第四代語言的特點:對用戶友善,一般用類自然語言、圖形或表格等描述方式,普通用戶很容易掌握多數(shù)與數(shù)據(jù)庫系統(tǒng)相結(jié)合,可直接對數(shù)據(jù)庫進行操作對許多應(yīng)用功能均有默認的假設(shè),用戶不必詳細說明每一件事情的做法程序碼長度及獲得結(jié)果的時間與使用COBOL語言相比約少一個數(shù)量級支持結(jié)構(gòu)化編程,易于理解和維護第21頁/共60頁
目前,第四代語言的種類繁多,尚無標準,在語法和能力上有很大差異,其中一些支持非過程式編程,更多的是既含有非過程語句,也含有過程語句。典型的4GL有:數(shù)據(jù)庫查詢語言、報表生成程序、應(yīng)用生成程序、電子表格、圖形語言等。多數(shù)4GL是面向領(lǐng)域的,很少是通用的。第22頁/共60頁
自然語言最理想的是可以使用自然語言(如英語、法語或漢語),使計算機能理解并立即執(zhí)行請求。但迄今為止,自然語言理解仍然是計算機科學(xué)研究中的一個難點,盡管在實驗室的研究中取得了一定的成果,但在現(xiàn)實中的應(yīng)用仍然是相當有限的。
第23頁/共60頁程序設(shè)計語言的選擇為一個特定的開發(fā)項目選擇編程語言時,通常要考慮如下因素:應(yīng)用領(lǐng)域算法和計算復(fù)雜性軟件運行環(huán)境用戶需求,特別是性能需求數(shù)據(jù)結(jié)構(gòu)的復(fù)雜性軟件開發(fā)人員的知識水平可用的編譯器與交叉編譯器第24頁/共60頁項目所屬的應(yīng)用領(lǐng)域常常是首要的標準COBOL適用于商業(yè)領(lǐng)域FORTRAN適用于工程和科學(xué)計算領(lǐng)域Prolog、Lisp適用于人工智能領(lǐng)域Smalltalk、C++適用于OO系統(tǒng)的開發(fā)有些語言適用于多個應(yīng)用領(lǐng)域,如C若有多種語言都適合于某項目的開發(fā)時,也可考慮選擇開發(fā)人員比較熟悉的語言第25頁/共60頁選擇高級語言還是低級語言優(yōu)先選擇高級語言開發(fā)和維護高級語言程序比開發(fā)和維護低級語言程序容易得多必要時使用低級語言高級語言程序經(jīng)編譯后所產(chǎn)生的目標程序的功效要比完成相同功能的低級語言程序低得多,所以在有些情況下會部分或全部使用低級語言第26頁/共60頁
使用低級語言的情況:對運行時間和存儲空間有過高要求的項目,如電子筆記本中的軟件在某些不能提供高級語言編譯程序的計算機上開發(fā)程序,如單片機上的軟件大型系統(tǒng)中對系統(tǒng)執(zhí)行時間起關(guān)鍵作用的模塊第27頁/共60頁內(nèi)容摘要程序設(shè)計語言程序設(shè)計風(fēng)格第28頁/共60頁程序設(shè)計風(fēng)格編程的依據(jù)是詳細設(shè)計的結(jié)果,因此程序的質(zhì)量主要取決于設(shè)計,但編程的質(zhì)量也在很大程度上影響著程序的質(zhì)量編程風(fēng)格主要包括:源程序中的內(nèi)部文檔數(shù)據(jù)說明語句構(gòu)造輸入/輸出第29頁/共60頁源程序文檔化在源程序中可包含一些內(nèi)部文檔,以幫助閱讀和理解源程序在源程序中的內(nèi)部文檔主要包括:標識符的命名注解程序的視覺組織第30頁/共60頁標識符的命名選擇含義明確的名字,使其能正確提示標識符所代表的實體例如,表示總量的變量名用Total,表示平均值的用Average等名字不要太長,太長會增加打字量,且易出錯。必要時可使用縮寫不用相似的名字,相似的名字容易混淆,不易發(fā)現(xiàn)錯誤如cm,cn,cmn,cnm,cnn,cmm第31頁/共60頁不用關(guān)鍵字作標識符同一個名字不要有多個含義名字中避免使用易混淆的字符。如數(shù)字0與字母O;數(shù)字1與字母I或l;數(shù)字2與字母z等第32頁/共60頁程序的注釋程序中的注解用來幫助人們理解程序,決不是可有可無的一些正規(guī)的程序文本中,注解行的數(shù)量約占整個源程序的1/3到1/2,甚至更多注解分為序言性注解和功能性注解第33頁/共60頁通常置于每個程序模塊的開頭部分,主要描述:模塊的功能模塊的接口:包括調(diào)用格式、參數(shù)的解釋、該模塊需要調(diào)用的其它子模塊名重要的局部變量:包括用途、約束和限制條件開發(fā)歷史:包括模塊的設(shè)計者、評審者、評審日期、修改日期以及對修改的描述序言性注釋第34頁/共60頁序言性注釋#include"compute.h"intMouseLeftFlag=0;/*鼠標左鍵單擊標志,全局變量1-單擊0-未單擊*//***********************************************************函數(shù)原型:voidinitmouse() **傳入?yún)?shù):無 **返回值:無 **函數(shù)功能:鼠標初始化 **鼠標初始化失敗,則程序終止退出 ***********************************************************/voidinitmouse(){ unionREGSireg,oreg; intret; ireg.x.ax=0;/*鼠標器0號功能:鼠標復(fù)位*/ int86(0x33,&ireg,&oreg);/*調(diào)用0x33中斷*/ ret=oreg.x.ax; if(ret!=-1)/*中斷返回不是-1,表示未找到鼠標驅(qū)動*/ { printf("Mouseisnotinstalled."); exit(1); }}第35頁/共60頁通常嵌在源程序體內(nèi),主要描述程序段的功能。書寫功能性注解時應(yīng)注意的問題:注解要正確,錯誤的注解比沒有注解更壞;為程序段作注解,而不是為每一個語句作注解;用縮進和空行,使程序與注釋容易區(qū)分;注解應(yīng)提供一些從程序本身難以得到的信息,而不是語句的重復(fù)。功能性注釋第36頁/共60頁功能性注釋#include"compute.h"intMouseLeftFlag=0;/*鼠標左鍵單擊標志,全局變量1-單擊0-未單擊*//***********************************************************函數(shù)原型:voidinitmouse() **傳入?yún)?shù):無 **返回值:無 **函數(shù)功能:鼠標初始化 **鼠標初始化失敗,則程序終止退出 ***********************************************************/voidinitmouse(){ unionREGSireg,oreg; intret; ireg.x.ax=0;/*鼠標器0號功能:鼠標復(fù)位*/ int86(0x33,&ireg,&oreg);/*調(diào)用0x33中斷*/ ret=oreg.x.ax; if(ret!=-1)/*中斷返回不是-1,表示未找到鼠標驅(qū)動*/ { printf("Mouseisnotinstalled."); exit(1); }}第37頁/共60頁例如,下面的模塊級注釋描述了公共的和私有的過程(在類模塊中稱為“方法”)、屬性及其數(shù)據(jù)類型,以及如何將該類作為對象來使用的有關(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)第38頁/共60頁通過在程序中添加一些空格、空行和縮進等技巧,幫助人們從視覺上看清程序的結(jié)構(gòu)例如,通過縮進技巧可清晰地觀察到程序的嵌套層次,同時還容易發(fā)現(xiàn)諸如“遺漏end”那樣的錯誤視覺組織第39頁/共60頁
IF(…)THEN
IF(…)THEN
……
ELSE
……
ENDIF
……
ELSE
……
ENDIF第40頁/共60頁自然的程序段之間可用空行隔開可通過添加空格使語句成分清晰,如
(A<-17)ANDNOT(B<=49)ORC
可寫成
(A<-17)ANDNOT(B<=49)ORC也可以通過添加括號突出運算的優(yōu)先級,避免發(fā)生運算的錯誤,如
a**(b**c)第41頁/共60頁放置大括號一般首選的方法是K&R方法:把左括號放在行尾,右括號放在行首。如:if
(X)
{Y}定義函數(shù)時應(yīng)當把左右括號都放在行首,如:int
F(int
x){//}注意,右括號所在的行不應(yīng)當有其它語句,除非跟隨著一個條件判斷。也就是do-while語句中的“while”和if-else語句中的“else”。例如:do
{body
of
do-loop}
while
(condition);if
(x
==
y)
{…
}
else
if
(x
>
y)
{...}
else
{…
}第42頁/共60頁數(shù)據(jù)說明為了使程序中數(shù)據(jù)說明更易于理解和維護,可采用以下風(fēng)格:數(shù)據(jù)說明的次序應(yīng)當規(guī)范化說明語句中變量安排有序化使用注解說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)第43頁/共60頁數(shù)據(jù)說明的次序應(yīng)當規(guī)范化數(shù)據(jù)說明次序規(guī)范化,使數(shù)據(jù)屬性容易查找,也有利于測試,排錯和維護原則上,數(shù)據(jù)說明的次序與語法無關(guān),其次序是任意的。但出于閱讀、理解和維護的需要,最好使其規(guī)范化,使說明的先后次序固定例如可按照以下說明次序:常量說明;簡單變量類型說明;數(shù)組說明;公用數(shù)據(jù)塊說明;所有的文件說明。第44頁/共60頁說明語句中變量安排有序化當多個變量名在一個說明語句中說明時,可以將這些變量按字母的順序排列,以便于查找應(yīng)該把INTEGERsize,length,width,cost,price寫成INTEGERcost,length,price,size,width
第45頁/共60頁使用注釋說明復(fù)雜數(shù)據(jù)結(jié)構(gòu)如果設(shè)計了一個復(fù)雜的數(shù)據(jù)結(jié)構(gòu),應(yīng)當使用注釋來說明在程序?qū)崿F(xiàn)時這個數(shù)據(jù)結(jié)構(gòu)的固有特點例如用戶自定義的數(shù)據(jù)類型,應(yīng)當在注釋中做必要的補充說明第46頁/共60頁語句構(gòu)造編碼階段的主要任務(wù)就是書寫程序語句。有關(guān)書寫語句的原則有幾十種,總起來說,希望每條語句盡可能簡單明了,能直截了當?shù)胤从吵绦騿T的意圖,不能為了片面追求效率而使語句復(fù)雜化。常用的規(guī)則如下:第47頁/共60頁1.在一行內(nèi)只寫一條語句在一行內(nèi)只寫一條語句,并且采取適當添加空格的辦法,使程序的邏輯和功能變得更加明確。許多程序設(shè)計語言允許在一行內(nèi)寫多個語句。但這種方式會使程序可讀性變差。因而不可取。第48頁/共60頁2.程序編寫首先應(yīng)當考慮清晰性程序編寫首先應(yīng)當考慮清晰性,不要刻意追求技巧性,使程序編寫得過于緊湊。例如,有一個用C語句寫出的程序段:
A[I]=A[I]+A[T];
A[T]=A[I]-A[T];
A[I]=A[I]-A[T];第49頁/共60頁
此段程序可能不易看懂,有時還需用實際數(shù)據(jù)試驗一下。實際上,這段程序的功能就是交換A[I]和A[T]中的內(nèi)容。目的是為了節(jié)省一個工作單元。如果改一下:
WORK=A[T];
A[T]=A[I];
A[I]=WORK;
就能讓讀者一目了然了。第50頁/共60頁3.程序要能直截了當?shù)卣f明程序員的用意。程序編寫得要簡單,寫清楚,直截了當?shù)卣f明程序員的用意。例如,
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
V[i][j]=(i/j)*(j/i)
除法運算(/)在除數(shù)和被除數(shù)都是整型量時,其結(jié)果只取整數(shù)部分,而得到整型量。第51頁/共60頁
當i<j時,i/j=0
當j<i時,j/i=0
得到的數(shù)組當i≠j時
V[i][j]=(i/j)*(j/i)=0
當i=j(luò)時
V[i][j]=(i/j)*(j/i)=1這樣得到的結(jié)果V是一個單位矩陣。第52頁/共60頁寫成以下的形式,就能讓讀者直接了解程序編寫者的意圖。
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;第53頁/共60頁4.其他常用規(guī)則讓編譯程序做簡單的優(yōu)化。盡可能使用庫函數(shù)避免不必要的轉(zhuǎn)移。盡量只采用三種基本的控制結(jié)構(gòu)來編寫程序。除順序結(jié)構(gòu)外,使用if-then-else來實現(xiàn)選擇結(jié)構(gòu);使用do-until或do-while來實現(xiàn)循環(huán)結(jié)構(gòu)。第54頁/共60頁求X,Y,Z中
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年馬鈴薯種植基地節(jié)能減排合同3篇
- 2024杭州市江干區(qū)電子商務(wù)平臺服務(wù)合同
- 2024有關(guān)維修合同范文
- 二零二五年度化妝品原料國際采購代理合同3篇
- 二零二五年度地簧門生產(chǎn)與市場推廣合作協(xié)議8篇
- 2024年貨車融資租賃協(xié)議樣本
- 2024木材行業(yè)國際貿(mào)易仲裁與爭議解決合同2篇
- 2024年物流服務(wù)協(xié)議標準模板版B版
- 2025版車貸反擔(dān)保車輛保險代理與理賠服務(wù)合同2篇
- 2024年運輸企業(yè)專屬商品購銷協(xié)議模板版B版
- 人教部編版八年級數(shù)學(xué)上冊期末考試卷及答案一
- 養(yǎng)老機構(gòu)安全管理培訓(xùn)課件
- (附答案)2024公需課《百縣千鎮(zhèn)萬村高質(zhì)量發(fā)展工程與城鄉(xiāng)區(qū)域協(xié)調(diào)發(fā)展》試題廣東公需科
- 安徽省蕪湖市2023-2024學(xué)年高一上學(xué)期1月期末英語試題
- 有門攝影課智慧樹知到期末考試答案2024年
- 臨床試驗觀察表(CRF)
- (正式版)JBT 11880.13-2024 柴油機 選擇性催化還原(SCR)系統(tǒng) 第13部分:催化劑分子篩
- 2024年江蘇宿遷永澤福壽園殯葬服務(wù)有限公司招聘筆試參考題庫含答案解析
- 鐵路職業(yè)規(guī)劃
- 審計常用法規(guī)培訓(xùn)課件
- 健康指南知己知彼了解你的身體質(zhì)量指數(shù)BMI
評論
0/150
提交評論