所謂軟體
架構,指的是軟體系統的整體結構,包括軟體子元素,這些元素的外部屬性以及元素元素之間的關係。
它不僅規定了系統有哪些主要軟體元素或模組,還定義了這些元素之間是如何互動的。它並不暴露每個元素的內部屬性(也叫區域性資訊),也就是說每個子模組的私有資訊是不劃歸到軟體架構的範疇的。需要注意的是,每個元素的外部屬性依然是軟體架構的一部分。這裡所謂的外部屬性,指的是乙個元素對其他元素所承擔的責任實體,包括:提供的服務,所需的服務,效能特徵,錯誤處理以及資源的使用。
元件:是軟體指令和內部狀態的乙個抽象單元,通過其介面提供對於資料的轉換。
聯結器:是對於元件之間的通訊、協調或者合作進行仲裁的一種機制。
資料:是元件通過乙個聯結器接收或傳送的資訊元素。
資料的例子包括位元組序列,訊息,編碼的引數以及過序列化過的物件,但不包括那些永久駐留或元件的私有資訊。聯結器的例子包括rpc遠端過程呼叫、訊息傳遞協議和資料流等。
每個系統都是由乙個或多個元素組成,並且這些元素之間都存在一定的關係。只有乙個元素的系統是最簡單的一種情況。
從不同的角度,系統可能獲得不同的結構表示圖。單單其中乙個檢視無法代表軟體架構。軟體架構是所有這些檢視的總和。在一般情況下,你可以選擇其中乙個或幾個結構檢視用以對軟體系統進行分析,理解或團隊間溝通。
軟體架構勾畫了乙個公用的框圖,可供不同的人參閱,學習和理解。這使得我們對軟體系統的理解和溝通更為順暢,具體體現為:
(1)與使用者討論和協商軟體需求;
(2)讓客戶及時了解我們的軟體開發進展及大致成本;
(3)對實施管理層的決定和人力調配起到一定幫助作用。
一方面,軟體架構對具體的軟體的實現是描述性的,但另一方面,它對軟體實現也是有限制性作用的。描述性可以幫助團隊更好的理解軟體系統,限制性可以對軟體的設計和編碼做出一定的限制。系統性的資源分配決定對子元素的實現也起到一定的限制作用。軟體架構必須做出系統性的取捨和權衡(trade-off).
(1)可以幫助管理者在團隊內部如何劃分任務,確保每個團隊成員明確自己的職責;
(2)可以幫助管理者做人力和其他開發成本預算。
(3)可以幫助組織開發文件。
(4)可以對軟體的整合起到幫助作用;
包括但不限於:安全性、可擴充套件性、可修改性、可重用性、效能等
軟體架構把變化歸為三類:
(1)區域性性變化。如,修改單個子元素或元件;
(2)大範圍變化。如,多個元件需要被修改;
(3)架構性變化。如修改整個系統拓撲檢視,修改元件之間的通訊模式或變更元素間的協調機制。
乙個好的軟體架構,一定是在改動最少的情況下,能夠很好的自適應各種變化。
(1)如建築領域一樣,軟體架構應充當乙個框架的作用。我們可以往框架填充軟體元件。也就是說,軟體元素是可以作為外掛程式整合到系統裡的;
(2)通過把某些軟體功能劃分到某個或某幾個軟體元素,我們可以分而治之,各個擊破;
(3)可以提前通過架構分析出哪些軟體元素可能對專案的成功存在風險,進而對資源分配進行調整。
某個軟體產品線,一般只有乙個軟體架構。但乙個軟體架構不應該只能適用於某個系統,它應該是乙個模型,可以為多個系統和多種系統服務。軟體設計者和開發者可以重用這些模型,受益於該模型,並將它運用到其他軟體產品線
什麼是軟體架構?
什麼是軟體架構呢?去年畢業前期,大小的企業輪流來到學校進行宣講,對所謂的軟體開發的職業規劃做出了五花八門的說明,每個公司都有自己的特色,但總體來講,還是分為技術和管理兩條線,我不太喜歡做管理,所以只關注技術的發展路線,大部分都是這樣的 初級程式設計師 中級程式設計師 高階程式設計師 架構師 技術總監...
什麼是軟體架構?
什麼是軟體架構呢?去年畢業前期,大小的企業輪流來到學校進行宣講,對所謂的軟體開發的職業規劃做出了五花八門的說明,每個公司都有自己的特色,但總體來講,還是分為技術和管理兩條線,我不太喜歡做管理,所以只關注技術的發展路線,大部分都是這樣的 初級程式設計師 中級程式設計師 高階程式設計師 架構師 技術總監...
什麼是軟體測試架構師
軟體測試架構師是乙個新職位,但確實是乙個非常必要的職位。文章向我們詳細介紹了軟體測試架構師這一新興職業,希望對大家能夠有所幫助。ad wot2014 使用者標籤系統與使用者資料化運營培訓專場 軟體測試架構師是乙個新職位,但確實是乙個非常必要的職位,主要有幾點 1.根據v模型 廣義測試概念等,靜態 測...