中文字幕色综合久久|国产AV成人精品播放|久久频精品99香蕉国产|国产精品爽爽ⅴa在线观看|丝袜美腿美女被狂躁长网站|亚洲精品欧美精品国产精品|国产精品va在线观看老妇女|国产精品99一区二区三区不卡

基于構(gòu)件的軟件開發(fā)前景分析(基于構(gòu)件的軟件工程)

軟件開發(fā) 3435
本篇文章給大家談?wù)劵跇?gòu)件的軟件開發(fā)前景分析,以及基于構(gòu)件的軟件工程對應(yīng)的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、軟件開發(fā)前景? 2、

本篇文章給大家談?wù)劵跇?gòu)件的軟件開發(fā)前景分析,以及基于構(gòu)件的軟件工程對應(yīng)的知識點,希望對各位有所幫助,不要忘了收藏本站喔。

本文目錄一覽:

軟件開發(fā)前景?

雖然互聯(lián)網(wǎng)領(lǐng)域的持續(xù)快速發(fā)展,尤其是近些年來移動互聯(lián)網(wǎng)領(lǐng)域的發(fā)展,在很大程度上促進(jìn)了IT行業(yè)領(lǐng)域?qū)τ陂_發(fā)人才的需求,但是目前要想找到一份適合自己的軟件開發(fā)崗位也并不容易,而要想獲得較高的薪資待遇往往也有很多具體的要求。

當(dāng)前軟件開發(fā)崗位對于從業(yè)者的門檻要求在進(jìn)一步提升,隨著云計算、大數(shù)據(jù)和人工智能相關(guān)技術(shù)的發(fā)展,軟件開發(fā)領(lǐng)域?qū)τ谙嚓P(guān)開發(fā)崗位的要求有三個較為明顯的變化,其一是開發(fā)人員需要具備多場景開發(fā)能力(全棧開發(fā));其二是開發(fā)人員需要具備一定的創(chuàng)新能力(研發(fā));其三是開發(fā)人員需要具備一定的行業(yè)知識。

在云計算技術(shù)的推動下,未來更多的行業(yè)定制化開發(fā)會轉(zhuǎn)向基于PaaS的開發(fā)方式,這將在很大程度上提升程序員的開發(fā)效率,所以未來行業(yè)定制化開發(fā)必然會出現(xiàn)崗位升級,這也將促使一部分技術(shù)結(jié)構(gòu)陳舊的程序員面臨一定的從業(yè)壓力。

在大數(shù)據(jù)技術(shù)和5G通信的推動下,程序員需要面對的開發(fā)場景也將得到進(jìn)一步的拓展,程序員不僅需要掌握常規(guī)的軟件開發(fā)技術(shù),還需要掌握一定的大數(shù)據(jù)技術(shù),所以要想就業(yè)到軟件開發(fā)崗位也并不容易。目前一部分開發(fā)企業(yè)對于全棧程序員更感興趣,而要想成為一名全棧程序員,無疑需要更多的積累。

軟件體系結(jié)構(gòu)的應(yīng)用現(xiàn)狀

形成研究熱點,仍處于非形式化水平

自20世紀(jì)90年代后期以來,軟件體系結(jié)構(gòu)的研究成為一個熱點。廣大軟件工作者已經(jīng)認(rèn)識到軟件體系結(jié)構(gòu)研究的重大意義和它對軟件系統(tǒng)設(shè)計開發(fā)的重要性,開展了很多研究和實踐工作。

從軟件體系結(jié)構(gòu)研究的現(xiàn)狀來看,當(dāng)前的研究和對軟件體系結(jié)構(gòu)的描述,在很大程度上來說還停留在非形式化的基礎(chǔ)上。軟件構(gòu)架師仍然缺乏必要的工具,這種工具應(yīng)該是顯式描述的、有獨立性的形式化工具。

在目前通用的軟件開發(fā)方法中,其描述通常是用非形式化的圖和文本,不能描述系統(tǒng)期望的存在于構(gòu)件之間的接口,不能描述不同的組成系統(tǒng)的組合關(guān)系的意義。難以被開發(fā)人員理解,更不能用來分析其一致性和完整性等特性。

當(dāng)一個軟件系統(tǒng)中的構(gòu)件之間幾乎以一種非形式化的方法描述時,系統(tǒng)的重用性也會受到影響,在設(shè)計一個系統(tǒng)結(jié)構(gòu)過程中的努力很難移植到另一個系統(tǒng)中去。對系統(tǒng)構(gòu)件和連接關(guān)系的結(jié)構(gòu)化假設(shè)沒有得到顯式的、形式化的描述時,把這樣的系統(tǒng)構(gòu)件移植到另一個系統(tǒng)中去將是有風(fēng)險的,甚至是不可能的。

軟件體系結(jié)構(gòu)的形式化方法研究

軟件體系結(jié)構(gòu)研究如果僅僅停留在非形式化的框圖階段,已經(jīng)難以適應(yīng)進(jìn)一步發(fā)展的需要。為支持基于體系結(jié)構(gòu)的開發(fā),需要有形式化建模符號、體系結(jié)構(gòu)說明的分析與開發(fā)工具。從軟件體系結(jié)構(gòu)研究的現(xiàn)狀來看,在這一領(lǐng)域近來已經(jīng)有不少進(jìn)展,其中比較有代表性的是美國卡耐基梅隆大學(xué)(Carnegie Mellon University)的Robert J.A11en于l997年提出的Wright系統(tǒng)。Wright是-種結(jié)構(gòu)描述語言,該語言基于一種形式化的、抽象的系統(tǒng)模型,為描述和分析軟件體系結(jié)構(gòu)和結(jié)構(gòu)化方法提供了一種實用的工具。Wright主要側(cè)重于描述系統(tǒng)的軟件構(gòu)件和連接的結(jié)構(gòu)、配置和方法。它使用顯式的、獨立的連接模型來作為交互的方式,這使得該系統(tǒng)可以用邏輯謂詞符號系統(tǒng),而不依賴特定的系統(tǒng)實例來描述系統(tǒng)的抽象行為。該系統(tǒng)還可以通過一組靜態(tài)檢查來判斷系統(tǒng)結(jié)構(gòu)規(guī)格說明的一致性和完整性。從這些特性的分析來說,Wright系統(tǒng)的確適用于對大型系統(tǒng)的描述和分析。

軟件體系結(jié)構(gòu)的建模研究

研究軟件體系結(jié)構(gòu)的首要問題是如何表示軟件體系結(jié)構(gòu),即如何對軟件體系結(jié)構(gòu)建模。根據(jù)建模的側(cè)重點的不同,可以將軟件體系結(jié)構(gòu)的模型分為5種:結(jié)構(gòu)模型、框架模型、動態(tài)模型、過程模型和功能模型。在這5個模型中,最常用的是結(jié)構(gòu)模型和動態(tài)模型。

(1)結(jié)構(gòu)模型

這是一個最直觀、最普遍的建模方法。這種方法以體系結(jié)構(gòu)的構(gòu)件、連接件和其他概念來刻畫結(jié)構(gòu),并力圖通過結(jié)構(gòu)來反映系統(tǒng)的重要語義內(nèi)容,包括系統(tǒng)的配置、約束、隱含的假設(shè)條件、風(fēng)格、性質(zhì)。研究結(jié)構(gòu)模型的核心是體系結(jié)構(gòu)描述語言。(2)框架模型

框架模型與結(jié)構(gòu)模型類似,但它不太側(cè)重描述結(jié)構(gòu)的細(xì)節(jié)而更側(cè)重于整體的結(jié)構(gòu)??蚣苣P椭饕砸恍┨厥獾膯栴}為目標(biāo)建立只針對和適應(yīng)該問題的結(jié)構(gòu)。

(3)動態(tài)模型

動態(tài)模型是對結(jié)構(gòu)或框架模型的補充,研究系統(tǒng)的大顆粒的行為性質(zhì)。例如,描述系統(tǒng)的重新配置或演化。動態(tài)可能指系統(tǒng)總體結(jié)構(gòu)的配置、建立或拆除通信通道或計算的過程。這類系統(tǒng)常是激勵型的。

(4)過程模型

過程模型研究構(gòu)造系統(tǒng)的步驟和過程。因而結(jié)構(gòu)是遵循某些過程腳本的結(jié)果。

(5)功能模型

該模型認(rèn)為體系結(jié)構(gòu)是由一組功能構(gòu)件按層次組成,下層向上層提供服務(wù)。它可以看作是一種特殊的框架模型。

這5種模型各有所長,也許將5種模型有機地統(tǒng)一在一起,形成一個完整的模型來刻畫軟件體系結(jié)構(gòu)更合適。例如,Kruchten在1995年提出了一個4+1的視角模型。4+1模型從5個不同的視角包括邏輯視角、過程視角、物理視角、開發(fā)視角和場景視角來描述軟件體系結(jié)構(gòu)。每一個視角只關(guān)心系統(tǒng)的一個側(cè)面,5個視角結(jié)合在一起才能夠反映系統(tǒng)的軟件體系結(jié)構(gòu)的全部內(nèi)容。4+1模型如圖1所示。

圖1 4+1模型

發(fā)展基于體系結(jié)構(gòu)的軟件開發(fā)模型

軟件開發(fā)模型是跨越整個軟件生存周期的系統(tǒng)開發(fā)、運行、維護(hù)所實施的全部工作和任務(wù)的結(jié)構(gòu)框架,給出了軟件開發(fā)活動各階段之間的關(guān)系。目前,常見的軟件開發(fā)模型大致可分為三種類型:

(1)以軟件需求完全確定為前提的瀑布模型。

(2)在軟件開發(fā)初始階段只能提供基本需求時采用的漸進(jìn)式開發(fā)模型,如螺旋模型等。

(3)以形式化開發(fā)方法為基礎(chǔ)的變換模型。

所有開發(fā)方法都是要解決需求與實現(xiàn)之間的差距。但是,這三種類型的軟件開發(fā)模型都存在這樣或那樣的缺陷,不能很好地支持基于軟件體系結(jié)構(gòu)的開發(fā)過程。因此,研究人員在發(fā)展基于體系結(jié)構(gòu)的軟件開發(fā)模型方面做了一定的工作。例如,為了形象地表示體系結(jié)構(gòu)的生命周期,北京郵電大學(xué)的周瑩新博士建立了一個軟件體系結(jié)構(gòu)的生命周期模型,該模型如圖2所示。圖2 軟件體系結(jié)構(gòu)的生命周期模型

軟件產(chǎn)品線體系結(jié)構(gòu)的研究

軟件體系結(jié)構(gòu)的開發(fā)是大型軟件系統(tǒng)開發(fā)的關(guān)鍵環(huán)節(jié)。體系結(jié)構(gòu)在軟件生產(chǎn)線的開發(fā)中具有至關(guān)重要的作用,在這種開發(fā)生產(chǎn)中,基于同一個軟件體系結(jié)構(gòu),可以創(chuàng)建具有不同功能的多個系統(tǒng)。在軟件產(chǎn)品族之間共享體系結(jié)構(gòu)和一組可重用的構(gòu)件,可以增加軟件工程和降低開發(fā)和維護(hù)成本。

一個產(chǎn)品線代表著一組具有公共的系統(tǒng)需求集的軟件系統(tǒng),它們都是根據(jù)基本的用戶需求對標(biāo)準(zhǔn)的產(chǎn)品線構(gòu)架進(jìn)行定制,將可重用構(gòu)件與系統(tǒng)獨有的部分集成而得到的。采用軟件生產(chǎn)線式模式進(jìn)行軟件生產(chǎn),將產(chǎn)生巨型編程企業(yè)。但目前生產(chǎn)的軟件產(chǎn)品族大部分是處于同一領(lǐng)域的。

基于構(gòu)件的軟件開發(fā)包括哪些要素

與傳統(tǒng)的軟件開發(fā)方式相比,基于構(gòu)件的軟件開發(fā)方法有什么突破呢?

一、體系結(jié)構(gòu)

軟件體系結(jié)構(gòu)代表了系統(tǒng)公共的高層次的抽象,它是系統(tǒng)設(shè)計成敗的關(guān)鍵。其設(shè)計的核心是能否使用重復(fù)的體系模式。傳統(tǒng)的應(yīng)用系統(tǒng)體系結(jié)構(gòu)從基于主機的集中式框架,到在網(wǎng)絡(luò)的客戶端上通過網(wǎng)絡(luò)訪問服務(wù)器的框架,都不能適應(yīng)目前企業(yè)所處的商業(yè)環(huán)境,原因是:

企業(yè)過分地依賴于某個供應(yīng)商的軟件和硬件產(chǎn)品。這種單一供應(yīng)商使得企業(yè)難以利用計算供應(yīng)商的免費市場,將計算基礎(chǔ)設(shè)施的重要決定交給第三方處理,這顯然不利于企業(yè)在合作伙伴之間共享信息。

不能適應(yīng)遠(yuǎn)程訪問的分布式、多層次異構(gòu)系統(tǒng)。

封裝的應(yīng)用系統(tǒng)在出現(xiàn)某種組織需要時,難以用定制來維護(hù)系統(tǒng),從而難以滿足多變的需求。

不能實現(xiàn)分析、設(shè)計核心功能重用,最多只能實現(xiàn)代碼重用。

如今,應(yīng)用系統(tǒng)已經(jīng)發(fā)展成為在Intranet和Internet上的各種客戶端可遠(yuǎn)程訪問的分布式、多層次異構(gòu)系統(tǒng)。CBSD為開發(fā)這樣的應(yīng)用系統(tǒng)提供

了新的系統(tǒng)體系結(jié)構(gòu)。它是標(biāo)準(zhǔn)定義的、分布式、模塊化結(jié)構(gòu),使應(yīng)用系統(tǒng)可分成幾個獨立部分開發(fā),可用增量方式開發(fā)。

這樣的體系結(jié)構(gòu)實現(xiàn)了CBSD的以下幾點目標(biāo):

能夠通過內(nèi)部開發(fā)的、第三方提供的或市場上購買的現(xiàn)有構(gòu)件,來集成和定制應(yīng)用軟件系統(tǒng)。

鼓勵在各種應(yīng)用系統(tǒng)中重用核心功能,努力實現(xiàn)分析、設(shè)計的重用。

系統(tǒng)都應(yīng)具有靈活方便的升級和系統(tǒng)模塊的更新維護(hù)能力。

封裝最好的實踐案例,并使其在商業(yè)條件改變的情況下,還能夠被采用,并能保留已有資源。

由此看出,CDSD從系統(tǒng)高層次的抽象上解決了復(fù)用性與異構(gòu)互操作性,這正是分布式網(wǎng)絡(luò)系統(tǒng)所希望解決的難題。

二、開發(fā)過程

傳統(tǒng)的軟件開發(fā)過程在重用元素、開發(fā)方法上都與CBSD有很大的不同。雖然面向?qū)ο蠹夹g(shù)促進(jìn)了軟件重用,但是,只實現(xiàn)了類和類繼承的重用。在整個系統(tǒng)和類之間還存在很大的缺口。為填補這個缺口,人們曾想了許多方法,如系統(tǒng)體系結(jié)構(gòu)、框架、設(shè)計模式等。

自從構(gòu)件出現(xiàn)以來,軟件的重用才得到了根本改變。CBSD實現(xiàn)了分析、設(shè)計、類等多層次上的重用。圖1顯示了它的重用元素分層實現(xiàn)。在分析抽象層上,重用

元素有子系統(tǒng)、類;在設(shè)計層上重用元素有系統(tǒng)體系結(jié)構(gòu)、子系統(tǒng)體系結(jié)構(gòu)、設(shè)計模式、框架、容器、構(gòu)件、類庫、模板、抽象類等。

在軟件開發(fā)方法上,CBSD引導(dǎo)軟件開發(fā)從應(yīng)用系統(tǒng)開發(fā)轉(zhuǎn)變?yōu)閼?yīng)用系統(tǒng)集成。建立一個應(yīng)用系統(tǒng)需要重用很多已有的構(gòu)件模塊,這些構(gòu)件模塊可能是在不同的時

間、由不同的人員開發(fā)的,并有各種不同的用途。在這種情況下,應(yīng)用系統(tǒng)的開發(fā)過程就變成對構(gòu)件接口、構(gòu)件上下文以及框架環(huán)境一致性的逐漸探索過程。例如,

在J2EE平臺上,用EJB框架開發(fā)應(yīng)用系統(tǒng),主要工作是將應(yīng)用邏輯,按session Bean、entity

Bean設(shè)計開發(fā),并利用JTS事務(wù)處理的服務(wù)實現(xiàn)應(yīng)用系統(tǒng)。其主要難點是事務(wù)劃分、構(gòu)件的部署與開發(fā)環(huán)境配置。概括地說,傳統(tǒng)的軟件開發(fā)過程是串行瀑布

式、流水線的過程;而CBSD是并發(fā)進(jìn)化式,不斷升級完善的過程。圖2顯示了它們的不同。

三、軟件方法學(xué)

軟件方法學(xué)是從各種不同角度、不同思路去認(rèn)識軟件的本質(zhì)。傳統(tǒng)的軟件方法學(xué)是從面向機器、面向數(shù)據(jù)、面向過程、面向功能、面向數(shù)據(jù)流、面向?qū)ο蟮炔粩鄤?chuàng)新

的觀點反映問題的本質(zhì)。整個軟件的發(fā)展歷程使人們越來越認(rèn)識到應(yīng)按客觀世界規(guī)律去解決軟件方法學(xué)問題。直到面向?qū)ο蠓椒ǖ某霈F(xiàn),才使軟件方法學(xué)邁進(jìn)了一大

步。但是,高層次上的重用、分布式異構(gòu)互操作的難點還沒有解決。CBSD發(fā)展到今天,才在軟件方法學(xué)上為解決這個難題提供了機會。它把應(yīng)用業(yè)務(wù)和實現(xiàn)分

離,即邏輯與數(shù)據(jù)的分離,提供標(biāo)準(zhǔn)接口和框架,使軟件開發(fā)方法變成構(gòu)件的組合。因此,軟件方法學(xué)是以接口為中心,面向行為的設(shè)計。圖3是其開發(fā)過程。

歸納起來,CBSD的軟件開發(fā)方法學(xué)應(yīng)包括下面幾方面:

對構(gòu)件有明確的定義。

基于構(gòu)件的概念需要有構(gòu)件的描述技術(shù)和規(guī)范,如UML、JavaBean、EJB、Servlet規(guī)范等。

開發(fā)應(yīng)用系統(tǒng)必須按構(gòu)件裁剪劃分組織,包括分配不同的角色。

有支持檢驗構(gòu)件特性和生成文檔的工具,確保構(gòu)件規(guī)范的實現(xiàn)和質(zhì)量測試。

總之,傳統(tǒng)的軟件方法學(xué)從草稿自頂向下進(jìn)行,對重用沒有提供更多的輔助。CBSD的軟件方法學(xué)要豐富得多,它是即插即用,基于體系結(jié)構(gòu),以接口為中心,將構(gòu)件有機組合,它把自頂向下和自底向上方法結(jié)合起來進(jìn)行開發(fā)。

四、開發(fā)組織機構(gòu)

傳統(tǒng)軟件的開發(fā)組織一般由分析員、設(shè)計員、程序員和測試員組成。對一個小的應(yīng)用系統(tǒng)來說,一個熟練的開發(fā)人員,可能兼顧以上多個角色。但對CBSD來說,因為構(gòu)件開發(fā)與應(yīng)用系統(tǒng)集成往往是分開進(jìn)行的,因此整個開發(fā)過程由六個角色來完成,他們是:

構(gòu)件開發(fā)者 也是構(gòu)件供貨商,這些大多數(shù)是中間件構(gòu)件提供者。

應(yīng)用構(gòu)件集成者 針對某應(yīng)用領(lǐng)域?qū)⒁延袠?gòu)件組合成更大的構(gòu)件模塊或容器, 作為系統(tǒng)部署的基本單元。

應(yīng)用系統(tǒng)部署者 將系統(tǒng)部署基本單元放入選定的平臺環(huán)境或基本框架中,完成軟件定制的要求。

開發(fā)平臺服務(wù)器供應(yīng)商 提供服務(wù)器、操作系統(tǒng)和數(shù)據(jù)庫等基本軟件。

應(yīng)用系統(tǒng)開發(fā)工具供應(yīng)商 提供構(gòu)件公共設(shè)施服務(wù)。

系統(tǒng)管理員 配置硬件、網(wǎng)絡(luò)和操作系統(tǒng),監(jiān)督和維護(hù)應(yīng)用系統(tǒng)者。

這六個角色的工作專業(yè)性很強,要兼顧成為多面手很不容易。目前已形成構(gòu)件開放市場,而且還很火紅。這也是當(dāng)今軟件人才大戰(zhàn)所遇的

一個困惑。因此,在CBSD中,如何組織好開發(fā)隊伍尤為重要,必須按本企業(yè)所具備人才來組織。特別重要的是:開發(fā)初期必須選好標(biāo)準(zhǔn)框架,以及統(tǒng)一的開發(fā)指

導(dǎo)方針,保證在整個開發(fā)過程中,各角色能隨時互相溝通。一般來說,CBSD的人員素質(zhì)決定了構(gòu)件的重用率。

五、構(gòu)造方法

傳統(tǒng)應(yīng)用軟件的構(gòu)造是用白盒子方法,應(yīng)用系統(tǒng)的實現(xiàn)全在代碼中,應(yīng)用邏輯和數(shù)據(jù)粘結(jié)在一起。而CBSD 的構(gòu)造是用白盒子和黑盒子相結(jié)合的方法。 基于構(gòu)件的框架是用兩個概念來支持演變:第一個概念是構(gòu)件有很強的性能接口,使構(gòu)件邏輯功能和構(gòu)件模型的實現(xiàn)都隱藏起來。這樣,只要接口相同,構(gòu)件就可以被替換。

第二個概念是隱式調(diào)用,即在基于構(gòu)件的框

架中,從來不直接給構(gòu)件的接口分配地址,只在識別構(gòu)件用戶后才分配地址。因此,構(gòu)件用戶只要了解接口要求和為構(gòu)件接口提供的引用后的返回信息

(該引用可能是一個構(gòu)件,也可能是一個構(gòu)件代理。對構(gòu)件用戶來說,構(gòu)件代理就是構(gòu)件,不用區(qū)分) 。

構(gòu)件接口的信息并不存入構(gòu)件內(nèi),而是存入構(gòu)件倉庫或注冊處。這樣才能保證構(gòu)件替換靈活,并很容易利用隱式調(diào)用去重新部署構(gòu)件。由于構(gòu)件的實現(xiàn)對用戶透明,

因此也使構(gòu)件能適應(yīng)各種不同的個性化要求。為此,構(gòu)件提供自檢和規(guī)范化兩個機制。自檢保證在不了解構(gòu)件的具體實現(xiàn)時,就能獲得構(gòu)件接口信息。例

如,JavaBean提供的自檢機制是Reflection和BeanInfo, 通過Reflection

可直接獲得Bean構(gòu)件的全部方法,通過BeanInfo可直接獲得構(gòu)件的許多復(fù)雜信息。

規(guī)范化允許不訪問構(gòu)件就可以修改它,如JavaBean提供的規(guī)范化是property sheet和customizer(定制器)。 通過property sheet提供一組簡單參數(shù),修改Bean的屬性。復(fù)雜的修改由用戶通過定制器設(shè)置參數(shù)完成。

基于構(gòu)件的軟件開發(fā)方法對什么菌有影響

軟件構(gòu)件技術(shù)是在軟件開發(fā)中避免重復(fù)勞動的解決方案。

通過軟件構(gòu)件技術(shù)可以提高軟件開發(fā)的效率和質(zhì)量。近十幾年來面向?qū)ο蠹夹g(shù)出現(xiàn)并逐步成為主流技術(shù),為軟件構(gòu)件技術(shù)提供了基本的技術(shù)支持。

軟件構(gòu)件技術(shù)研究成為熱點,被視為解決軟件危機、提高軟件生產(chǎn)效率和質(zhì)量的現(xiàn)實可行的途徑。

關(guān)于基于構(gòu)件的軟件開發(fā)前景分析和基于構(gòu)件的軟件工程的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。

掃碼二維碼