軟體開發思路:整合,複用,分享

來源:互聯網
上載者:User

昨天表了一篇文章《軟體開發關鍵字:整合和複用》。關於整合和複用,是有一些交集的。

今天繼續這個話題。不過題目變了一下。

 

 

以複用的思路指導開發:

1、構建系統的時候,把多個子系統系統的交集部分抽象出來,作為系統的基礎設施,為多個子系統提供服務。我們公司是從事企業語音系統開發,包括調度系統,會議系統,話務中心系統等。這幾個子系統的交集,典型的比如企業通訊錄,計費,通訊記錄,網管,都可以單獨抽象出來做為基礎設施為各個子系統提供服務。
2、在構建程式的時候,可以將能夠複用的模組以庫的形式抽象出來。比如,軟交換系統需要使用sip協議棧,那麼就可以把sip協議棧開發成為一個庫,這樣就可以在其他程式(比如TG)中複用sip庫。如果軟交換程式要重新開發,也可以直接複用以前的sip庫。其他相同的比如tcp分包流控模組,定時器模組等。
3、再更低一個層次,就是子程式的複用。把重複的操作以封裝成一個庫,比如TCP建立串連和關閉串連,收發包等。
按照這種思路開發的好處:
1、避免重複開發,提高開發效率。
2、程式結構可以快速的演化。比如,舊版的軟交換使用的sip庫,可以在新版軟交換開發的時候直接被拿來使用。類似的庫越多,軟交換在重新架構的時候就可以只對核心部分進行重新設計,而其他部分都可以重用。
3、整個系統可以靈活的演化。子系統的交集:企業通訊錄,計費,通訊記錄,網管等以基礎設施的方式支撐整個系統,當整個系統演化的時候,可以直接重用這些基礎設施,或者進行小範圍的更改後進行重用。這樣的話,就可以只對系統的核心部分——商務邏輯部分——進行重新設計,達到系統升級的目的。

以整合的思路指導開發:

1、在開發一個新產品的時候,要首先看看公司以往有沒有優秀的解決方案、軟體模組可以整合以提高效率。其次,要開源世界有沒有優秀成熟的解決方案可以整合。比如,要在c和c++上進行xml編解碼,那麼可以尋找一些優秀的開源解決方案,比如tinyxml,而未必要自己實現。在比如,如果需要工作流程引擎可以參考一下JBPM。
好處:
1、藉助已有的優秀方案可以加速軟體開發過程,避免重複開發,保證產品品質。
2、在整合的過程中,會逐漸積累研發經驗,形成研發平台,從而變成公司的寶貴資產。

以分享的思路指導開發:

1、在公司內部分享開發中的可重用的軟體模組,技術積累,管理經驗。促進知識流動。
2、面向公司外部分享開發中的可重用的代碼模組,技術積累,管理經驗。部分可重用的模組可以考慮以開源的形式貢獻出來。利用社區的力量,推動自身軟體研發實力的發展。
好處:
1、整合和分享結合起來,實現“使用開源,回饋開源”,促進技術進步。
2、利用開源社區的反饋,促進自身技術進步。
3、促進知識,經驗的流動。

整合和複用的好處是,可以使程式,系統的核心部分獨立於其他部分而快速的演化,從而達到程式、系統快速升級的目的。

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.