點(diǎn)擊進(jìn)入:2011計(jì)算機(jī)等考二級公共基礎(chǔ)知識講義匯總>>
2.2 結(jié)構(gòu)化程序設(shè)計(jì)(面向過程的程序設(shè)計(jì)方法)
1、結(jié)構(gòu)化程序設(shè)計(jì)方法的主要原則可以概括為:自頂向下,逐步求精,模塊化,限制使用goto語句。
(1)自頂向下。程序設(shè)計(jì)時(shí),應(yīng)先考慮總體,后考慮細(xì)節(jié);先考慮全局目標(biāo),后考慮局部目標(biāo)。不要一開始就過多追求眾多的細(xì)節(jié),先從最上層總目標(biāo)開始設(shè)計(jì),逐步使問題具體化。
(2)逐步求精。對復(fù)雜問題,應(yīng)設(shè)計(jì)一些子目標(biāo)作過渡,逐步細(xì)化。
(3)模塊化。一個(gè)復(fù)雜問題,肯定是由若干稍簡單的問題構(gòu)成。模塊化是把程序要解決的總目標(biāo)分解為分目標(biāo),再進(jìn)一步分解為具體的小目標(biāo),把每個(gè)小目標(biāo)稱為一個(gè)模塊。
(4)限制使用goto語句。
2、結(jié)構(gòu)化程序的基本結(jié)構(gòu):順序結(jié)構(gòu),選擇結(jié)構(gòu),重復(fù)結(jié)構(gòu)。
1)順序結(jié)構(gòu)。一種簡單的程序設(shè)計(jì),即按照程序語句行的自然順序,一條語句一條語句地執(zhí)行程序,它是最基本、最常用的結(jié)構(gòu)。
2)選擇結(jié)構(gòu)。又稱分支結(jié)構(gòu),包括簡單選擇和多分支選擇結(jié)構(gòu),可根據(jù)條件,判斷應(yīng)該選擇哪一條分支來執(zhí)行相應(yīng)的語句序列。
3)重復(fù)結(jié)構(gòu)。又稱循環(huán)結(jié)構(gòu),可根據(jù)給定的條件,判斷是否需要重復(fù)執(zhí)行某一相同的或類似的程序段。
僅僅使用順序、選擇和循環(huán)三種基本控制結(jié)構(gòu)就足以表達(dá)各種其他形式結(jié)構(gòu),從而實(shí)現(xiàn)任何單入口/單出口的程序。
2.3 面向?qū)ο蟮某绦蛟O(shè)計(jì)
客觀世界中任何一個(gè)事物都可以被看成是一個(gè)對象,面向?qū)ο蠓椒ǖ谋举|(zhì)就是主張從客觀世界固有的事物出發(fā)來構(gòu)造系統(tǒng),提倡人們在現(xiàn)實(shí)生活中常用的思維來認(rèn)識、理解和描述客觀事物,強(qiáng)調(diào)最終建立的系統(tǒng)能夠映射問題域。也就是說,系統(tǒng)中的對象及對象之間的關(guān)系能夠如實(shí)地反映問題域中固有的事物及其關(guān)系。
面向?qū)ο蠓椒ǖ闹饕獌?yōu)點(diǎn):(1)與人類習(xí)慣的思維方法一致;(2)穩(wěn)定性好;(3)可重用性好;(4)易于開發(fā)大型軟件產(chǎn)品;(5)可維護(hù)性好。
*:面向?qū)ο蟮某绦蛟O(shè)計(jì)主要考慮的是提高軟件的可重用性。
對象是面向?qū)ο蠓椒ㄖ凶罨镜母拍,可以用來表示客觀世界中的任何實(shí)體,對象是實(shí)體的抽象。面向?qū)ο蟮某绦蛟O(shè)計(jì)方法中的對象是系統(tǒng)中用來描述客觀事物的一個(gè)實(shí)體,是構(gòu)成系統(tǒng)的一個(gè)基本單位,由一組表示其靜態(tài)特征的屬性和它可執(zhí)行的一組操作組成。對象是屬性和方法的封裝體。
屬性即對象所包含的信息,它在設(shè)計(jì)對象時(shí)確定,一般只能通過執(zhí)行對象的操作來改變。
操作描述了對象執(zhí)行的功能,操作也稱為方法或服務(wù)。操作是對象的動(dòng)態(tài)屬性。
*:一個(gè)對象由對象名、屬性和操作三部分組成。
對象的基本特點(diǎn):標(biāo)識惟一性,分類性,多態(tài)性,封裝性,模塊獨(dú)立性好。
(1)標(biāo)識惟一性。指對象是可區(qū)分的,并且由對象的內(nèi)在本質(zhì)來區(qū)分,而不是通過描述來區(qū)分。
(2)分類性。指可以將具有相同屬性的操作的對象抽象成類。
(3)多態(tài)性。指同一個(gè)操作可以是不同對象的行為。
(4)封裝性。從外面看只能看到對象的外部特性,即只需知道數(shù)據(jù)的取值范圍和可以對該數(shù)據(jù)施加的操作,根本無需知道數(shù)據(jù)的具體結(jié)構(gòu)以及實(shí)現(xiàn)操作的算法。對象的內(nèi)部,即處理能力的實(shí)行和內(nèi)部狀態(tài),對外是不可見的。從外面不能直接使用對象的處理能力,也不能直接修改其內(nèi)部狀態(tài),對象的內(nèi)部狀態(tài)只能由其自身改變。
*:信息隱蔽是通過對象的封裝性來實(shí)現(xiàn)的。
(5)模塊獨(dú)立性好。對象是面向?qū)ο蟮能浖幕灸K,它是由數(shù)據(jù)及可以對這些數(shù)據(jù)施加的操作所組成的統(tǒng)一體,而且對象是以數(shù)據(jù)為中心的,操作圍繞對其數(shù)據(jù)所需做的處理來設(shè)置,沒有無關(guān)的操作。從模塊的獨(dú)立性考慮,對象內(nèi)部各種元素彼此結(jié)合得很緊密,內(nèi)聚性強(qiáng)。
類是指具有共同屬性、共同方法的對象的集合。所以類是對象的抽象,對象是對應(yīng)類的一個(gè)實(shí)例。
消息是一個(gè)實(shí)例與另一個(gè)實(shí)例之間傳遞的信息。消息的組成包括:(1)接收消息的對象的名稱;(2)消息標(biāo)識符,也稱消息名;(3)零個(gè)或多個(gè)參數(shù)。
*:在面向?qū)ο蠓椒ㄖ,一個(gè)對象請求另一個(gè)對象為其服務(wù)的方式是通過發(fā)送消息。
繼承是指能夠直接獲得已有的性質(zhì)和特征,而不必重復(fù)定義他們。繼承分單繼承和多重繼承。單繼承指一個(gè)類只允許有一個(gè)父類,多重繼承指一個(gè)類允許有多個(gè)父類。
*:類的繼承性是類之間共享屬性和操作的機(jī)制,它提高了軟件的可重用性。
多態(tài)性是指同樣的消息被不同的對象接受時(shí)可導(dǎo)致完全不同的行動(dòng)的現(xiàn)象。(學(xué)吧學(xué)吧獨(dú)家稿件)
本章應(yīng)考點(diǎn)撥:本章在考試中會出現(xiàn)約1個(gè)題目,所占分值大約占2分,是出題量較小的一章。本章內(nèi)容比較少,也很簡單,掌握住基本的概念就可以輕松應(yīng)對考試了,所以在這部分丟分,比較可惜。
相關(guān)推薦:2011計(jì)算機(jī)等考二級公共基礎(chǔ)知識要點(diǎn)匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |