青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

www.myuml.net

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  5 隨筆 :: 0 文章 :: 14 評論 :: 0 Trackbacks

如何設(shè)計一個應(yīng)用軟件

當今時代軟件行業(yè)各種新的技術(shù)層出不窮。但是我認為軟件行業(yè)最根本的技術(shù)在于以下幾個內(nèi)容:
1、操作系統(tǒng)。
2、編譯系統(tǒng)。
3、數(shù)據(jù)庫管理系統(tǒng)。
4、協(xié)議。
5、算法。
6、應(yīng)用軟件。

這六種技術(shù)構(gòu)成了各種各樣新技術(shù)的根基。

計算機發(fā)展至今,以應(yīng)用軟件種類最為煩多。國外有著眾多商業(yè)化的應(yīng)用軟件提供商。Windows下我們所熟知的應(yīng)用軟件有:MS Office\Photoshop\Flash\Firework等。我這里所討論的應(yīng)用軟件指的是經(jīng)典的應(yīng)用軟件,它們有一些共同的特點:可以創(chuàng)建新的文檔,可以保存文檔,可以讀取文檔,可以對文檔按要求進行修修改改。Windows下記事本可以認為是最簡單最基本的應(yīng)用程序。而其它一些軟件,例如掃雷、紙牌歸入游戲軟件,winamp歸入娛樂軟件,DAEMON Tools Lite歸為工具軟件,它們均不歸入我在這里所討論的應(yīng)用軟件。

國內(nèi)的應(yīng)用軟件能夠在國際舞臺上占據(jù)一席之地的并不多。歸根結(jié)底是利益的問題,因為應(yīng)用軟件的開發(fā)存在著開發(fā)周期長、設(shè)計非常重要、需要開發(fā)人員多、投入大等問題,并且短期內(nèi)不能實現(xiàn)贏利。我們可以想像,從頭開發(fā)一個類似于Photoshop的軟件,需要多少人月才能完成。因此國內(nèi)的許多廠商寧可花費巨資去開發(fā)游戲,因為游戲有有效的贏利方式。

應(yīng)用軟件的開發(fā)需要沉淀。這里的沉淀理解為“一個城市有著深厚文化的沉淀”的沉淀。因為應(yīng)用軟件總是在不斷的升級過程中。升級似乎不會有盡頭。升級也伴隨著操作系統(tǒng)的升級。有時可能需要將應(yīng)用軟件從一個平臺移動到另一個平臺上。升級的主要目的是增加新的功能,增加合理的智能提示,校正以前的一些BUG,改變更加優(yōu)美的界面等等。例如我們所熟知的MS Office的升級之路:MS Office 97/MS Office 2000/MS Office XP/ MS Office 2007,這中間可能還會有我漏掉的一些版本。

很顯然,應(yīng)用軟件的設(shè)計非常重要。一個好的設(shè)計可以使得優(yōu)秀的軟件在升級過程中后來居上,一個不好的設(shè)計可能會使得開發(fā)陷入泥潭,使得升級工作無法進行。

以下內(nèi)容我以我所寫的MyUML建模軟件為例,討論如何設(shè)計一個應(yīng)用軟件,希望能夠給希望從事這一領(lǐng)域的人們一點啟示。myuml在ww.myuml.net下載。

寫MyUML的過程中,我感覺到寫應(yīng)用軟件可以歸納為一個框架模式,我這里所說的模式可以理解為“分析和設(shè)計模式”中的模式。實質(zhì)上這種模式類似于MVC模式,我只不過是將其具體化、拓展。

一、首先要考慮開發(fā)平臺、開發(fā)語言。
如果使用Java語言進行開發(fā),可能就不需要考慮運行的操作系統(tǒng)了。例如建模軟件中的argoUML,在Linux和Windows下都能不做更改、很好的運行。但是Java語言所寫的軟件在速度上還是偏慢,不過隨著電腦硬件速度的提高,這個問題正在得到解決。

如果在Windows下進行開發(fā),可能還需要考慮微軟公司的ActiveX技術(shù),通俗的講,就是可以直接在瀏覽器中使用我們所編寫的應(yīng)用程序打開我們的應(yīng)用程序所支持的文檔,或者在Word中直接插入我們的應(yīng)用程序所支持的文檔,或者在我們的應(yīng)用程序中插入Excel文檔等等。

我一直比較偏愛c++,因此使用了c++來寫這一個應(yīng)用程序。為了便于移植,沒有考慮微軟公司的COM技術(shù)。

二、應(yīng)用軟件的內(nèi)核:對象或者數(shù)據(jù)結(jié)構(gòu)+算法
很顯然,面向?qū)ο笙鄬τ诿嫦蜻^程更適用于寫應(yīng)用軟件。
這里涉及到主要問題是應(yīng)用軟件應(yīng)該采用怎么樣的對象來表達對應(yīng)的文檔。

注意在此時,我們的應(yīng)用程序還沒有任何圖形化的界面。我們希望能做的內(nèi)核能夠達到這樣的要求就行了:在測試程序中,說的通俗一點,就是我們寫一個main函數(shù),然后在該函數(shù)中,我們可以創(chuàng)建一個對象,然后調(diào)用該對象的各種方法,跟蹤其方法,查看是否能夠?qū)崿F(xiàn)要求。

例如我寫MyUML的過程中,就一直使用這種方法來測試內(nèi)核的正確性。我會創(chuàng)建一個模型對象,然后調(diào)用這個對象的“添加包”方法、“添加類”方法等等。做這些事的時候,我甚至根本就沒有考慮過以后的用戶接口界面也就是圖形界面究竟是什么樣子。

三、應(yīng)用軟件的文檔:文件、文件格式、文件保存及讀取。

通常來說,一個實用的應(yīng)用軟件,其文檔所對應(yīng)的對象(或者數(shù)據(jù)結(jié)構(gòu))是非常復(fù)雜非常龐大的。例如Word,一篇文檔可能包括各種不同格式的文字、插入的圖像、自己繪制的圖形、甚至還有鏈接的Excel對象等等。因此這里還有一個大的問題需要解決:如何將這個對象的所有信息正確地保存到文件上及如何將其從文件中正確的讀取出對應(yīng)的文檔對象?

解決這個問題同樣有多種方式,一種方式是創(chuàng)建自己的專有文件格式,例如DOC文檔、FLASH動畫文檔、Photoshop所創(chuàng)建的PSD文檔,這時自己可能需要做詳細的文檔(這里的文檔指的是記錄這些專有文件格式的文檔),將這些格式進行記錄,供開發(fā)人員參考。第二種方式是采用公開的文件格式,當然最好采用標準化后的文件格式。第三種方式是采用XML來記錄文件格式。

我使用的是第三種方式。XML用來記錄對象信息有一種獨天得厚的優(yōu)勢。當然具體內(nèi)容請各位朋友們參考相關(guān)書籍。在這里涉及到第一個支持庫的問題:是使用已有的XML解析庫還是自己寫一個XML解析庫?當然網(wǎng)上也有開源的高手們所寫的XML解析庫拿來參考。我最后選擇了APACHE的XERCES_C解析庫。

談到庫的時候順便談一下STL庫。STL雖然是一個標準庫,但是有許多實現(xiàn)。到底選擇哪一個呢?仁者見仁,智者見智。我選擇的是STL port。

這些庫中也可能會存在BUG或者不足之處。當然出現(xiàn)BUG的可能性是非常非常小的。如果碰到對中文的支持不夠,改為Unicode編碼即可。同時建議我們寫程序的時候,如果有用到這些庫,最好循規(guī)蹈矩,不要玩花樣。

四、應(yīng)用軟件的界面及各種輔助庫。
如果內(nèi)核寫出了一個大概,就可以考慮寫界面。根據(jù)我的經(jīng)驗,內(nèi)核不可能一次到位,最終還是要修改的,不過只要將內(nèi)核和界面的接口處理好,實現(xiàn)我們軟件工程中的最小耦合,內(nèi)核和界面的相互間的影響并不大。

商業(yè)廠家可以請專業(yè)人士設(shè)計界面。相對來說,界面離不開:框架窗口、菜單、工具欄。用戶使用應(yīng)用軟件通常從菜單入手或者從工具欄入手。

我們個人寫界面通常也不大可能直接從Windows SDK寫起,當然排除一些高手。順便提一句,我看過羅云彬先生的《Win32匯編教程》(書名忘記了,大致是這個意思,現(xiàn)在我這里不能上網(wǎng),不能確定),看完后,我認為完全可以從匯編語言寫界面,不過效率可能會低一點。

界面庫也有許多可以供選擇。Windows下最有名的當然是MFC了。我寫MyUML的時候,QT還沒有出LGPL許可證,c系的圖形庫我用著實在是有些不習(xí)慣。最后我選擇了MFC。

同時我們可能還需要一些寫一些輔助庫來實現(xiàn)我們的應(yīng)用程序。例如在MyUML建模軟件中,需要處理繪圖,因此我將相應(yīng)的繪圖的功能寫在一個圖形庫中。

五、應(yīng)用軟件的視圖
視圖的功能是將文檔以可視的方式顯示給用戶。我們可能會需要以不同的方式查看文檔,或者我們需要查看文檔的不同內(nèi)容,因此可能需要有多個視圖。

例如在MyUML建模軟件中,我們可能需要查看一個模型的內(nèi)容,這個模型中有哪些包、有哪些圖、有哪些類等等,這里我們需要用一種視圖來表示模型的內(nèi)容。通常使用樹的方式比較合適。我們也可能需要查看一個類的屬性,一個圖的內(nèi)容。這時圖的內(nèi)容可以使用MFC中CView類的派生類的方式,而類的屬性可以使用一個對話框來表示,它們都可以視為視圖。盡管在MFC中視圖類是一種特殊的類。

洋洋灑灑寫了這么多。真正實現(xiàn)一個實用的的應(yīng)用軟件的時候,可能會遇到各種各樣的困難,但是這些困難都是可以一一克服的。因為別人能做到的,我們也能做到。

posted on 2009-10-27 00:55 尋舟 閱讀(2420) 評論(14)  編輯 收藏 引用

評論

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 08:51 李佳
文章寫的不錯 應(yīng)用軟件 國產(chǎn)的似乎確實比較少 打開自己的開始菜單一看... 除了迅雷還差不多 其他的都沒了...   回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件[未登錄] 2009-10-27 11:37 風(fēng)
挺不錯的!  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件[未登錄] 2009-10-27 15:08 eXile
myuml是作者開發(fā)的嗎,似乎還不錯,很輕量,界面也還可以。試用了一下,還是有些需要改進。比如,新建一個方法,過程太繁瑣,其實可以直接輸入:method(arg1:int, arg2:int):int,然后解析出它的參數(shù)和返回值,而不需要一個一個控件在那點半天。另外為什么發(fā)布的是DEBUG版的?  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 15:35 chentan
國內(nèi)其實也有不少的精品應(yīng)用軟件, 比如edraw, 易控
  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 16:29 尋舟
@李佳

呵呵,其實迅雷也不屬于我文中所討論的狹義的應(yīng)用軟件范圍。我覺得迅雷應(yīng)該歸為下載工具軟件類吧。  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 16:31 尋舟
@風(fēng)

謝了,只是自己的一點心得,和大家共享經(jīng)驗、探討不足。  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 16:43 尋舟
@eXile

非常感謝您使用MyUML并提出您的意見。
關(guān)于新建方法,說實在話,我是借鑒了PowerDesigner中的新建方法,試用PowerDesigner的時候就覺得那種只需要點鼠標的新建方法操作過程很不錯。至于您所說的直接輸入:method(arg1:int, arg2:int):int的建議其實也非常好。就好像有點類似于AutoCAD中,既可以通過鼠標也可以通過命令來完成一系列的操作。

我從一開始發(fā)布的版本就是DEBUG版本,因為這是我由于個人興趣開發(fā)的一個軟件,我還沒有想到要把它弄得有多正規(guī),呵呵,如果有朋友們想要Release版本,我會重新編譯并發(fā)布。實質(zhì)上,C++的DEBUG版本給我的感覺也是速度非常快,雖然可能軟件包會大一些。

近期我會發(fā)布新版本,其中加入Perl\Python\Ruby\PHP5的正向工程。希望您能繼續(xù)關(guān)注MyUML  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-27 16:56 尋舟
@chentan

國內(nèi)的應(yīng)用軟件需要來自各方的關(guān)注和支持。

我們國家計算機行業(yè)還是有許多人才的,但是從事計算機行業(yè)的人們背負的壓力太重了,成家、房子、孩子讀書等等。

我很佩服國外一些程序員和他們所支撐的軟件。他們似乎是為了理想去寫程序。而我們,達到這一種境界很難。  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-28 12:30 凡客誠品
國內(nèi)其實也有不少的精品應(yīng)用軟件  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-28 12:59 中國研發(fā)網(wǎng)
寫的不錯,不知道你的MyUML是否考慮開源呢?  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-28 14:07 尋舟
@中國研發(fā)網(wǎng)
有點事,等會來回復(fù)  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-28 16:55 尋舟
@中國研發(fā)網(wǎng)
先謝謝您對MyUML的支持。
今天中午剛發(fā)布MyUML091115版,支持正向生成Perl\Ruby\Python\PHP5代碼,同時集成了SciTE。

開源當然在我的考慮之列。不過開源之后呢?如果沒有一個團體或者社區(qū)來維護這個軟件,MyUML會有比較好的前景嗎?如果有公司愿意接手MyUML并且保持免費,我可以選擇將此軟件開源。

我從沒有收過MyUML一分錢的許可費或者注冊費,那是因為我一直在猶豫之中。到底是將MyUML做成共享軟件,面向國外收費?還是免費開源?

如果有一天,我收了MyUML的第一份注冊費的時候,那么MyUML也就不太可能開源了。但是目前來說,開源還是我的選擇之一。  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-29 00:39 空明流轉(zhuǎn)
賣吧。別開源,開源會死的。  回復(fù)  更多評論
  

# re: 如何設(shè)計一個應(yīng)用軟件 2009-10-29 12:23 尋舟
@空明流轉(zhuǎn)

謝謝朋友提醒。
一個軟件時間做長了,心里會產(chǎn)生感情。我正是擔心開源后MyUML沒有好下場,所以一直在猶豫之中。

寫這個軟件,最初的目的也就是好玩。在一些人的鼓勵下做到今天這樣,連我自己都有點意外。我現(xiàn)在如果做點東西,或者在MyUML上添加新的模塊,也會選擇MyUML來進行建模。我自己選擇自己所做的建模軟件,正是對其有信心的體現(xiàn)。

但是如果做收費軟件我又擔心我沒有那個耐心和責任感。我覺得我是一個比較散漫的人。做免費軟件,其實感覺也挺不錯的,不用擔負用戶的責罵,不用擔心別人的破解,不用為了實現(xiàn)用戶的要求加班加點的趕工。雖然我前幾天也曾經(jīng)每天都熬夜到兩三點,不過那是我的自愿。我只是業(yè)余時間寫寫軟件,做點自己喜歡的東西,能夠給朋友們帶來一個新的選擇,我就覺得很高興了。  回復(fù)  更多評論
  


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产精品久久久久秋霞影院| 亚洲图色在线| 卡一卡二国产精品| 久久精品一本| 亚洲国产一区二区a毛片| 亚洲国产日韩一区| 欧美激情一区| 亚洲欧美一级二级三级| 性欧美video另类hd性玩具| 狠狠色狠狠色综合| 亚洲国产精品成人一区二区 | 亚洲美女精品一区| 欧美日韩国产色视频| 午夜精品久久久久久99热软件| 亚洲综合第一页| 亚洲福利国产| 中文精品视频一区二区在线观看| 国产女主播一区| 欧美大学生性色视频| 欧美日韩一区二区在线观看| 欧美综合国产| 欧美大片va欧美在线播放| 中国成人在线视频| 久久久福利视频| 亚洲午夜一区二区三区| 欧美伊人久久久久久午夜久久久久 | 亚洲免费观看| 国产综合18久久久久久| 亚洲第一二三四五区| 国产精品免费看| 欧美激情一区二区久久久| 国产精品成人免费| 欧美成人精品1314www| 国产精品久久久久久久久久三级| 久久久久久久综合| 欧美日韩亚洲网| 欧美+日本+国产+在线a∨观看| 欧美日韩日本国产亚洲在线| 久久亚洲一区二区| 国产精品成人一区二区艾草| 欧美韩日视频| 国产在线观看精品一区二区三区 | 久久久噜噜噜久久中文字幕色伊伊 | 久久精品人人做人人综合| 欧美国产在线观看| 久久亚洲图片| 国产日韩欧美一区二区三区在线观看| 亚洲国产高清一区| 在线播放中文一区| 亚洲欧美成人一区二区在线电影| 亚洲日本免费电影| 久久久久久9| 久久精品99久久香蕉国产色戒| 欧美日韩三级电影在线| 欧美韩国在线| 亚洲国产欧美久久| 久久综合电影一区| 老牛国产精品一区的观看方式| 国产精品有限公司| 亚洲自拍偷拍网址| 午夜精品成人在线| 国产精品第三页| 在线视频你懂得一区二区三区| 亚洲美女视频在线观看| 男女视频一区二区| 亚洲国产人成综合网站| 亚洲经典在线看| 蜜桃av一区二区| 亚洲成人在线视频播放 | 午夜精彩视频在线观看不卡| 亚洲永久精品大片| 国产精品嫩草99a| 亚洲欧美电影在线观看| 先锋影院在线亚洲| 国产亚洲制服色| 久久精品一区二区三区不卡牛牛| 久久亚洲色图| 亚洲国产精品成人综合色在线婷婷| 久久精品国产免费观看| 麻豆精品视频| 亚洲精品无人区| 欧美日韩国产不卡| 在线视频日韩精品| 欧美专区在线| 亚洲国产小视频| 欧美日韩免费观看一区二区三区 | 性久久久久久久久| 国产一区二区三区黄视频| 久久精品综合网| 亚洲二区免费| 亚洲你懂的在线视频| 国产日韩欧美综合在线| 开心色5月久久精品| 亚洲精品乱码视频| 欧美亚洲日本网站| 依依成人综合视频| 欧美精品日韩综合在线| 亚洲免费伊人电影在线观看av| 久久久久国产一区二区| 亚洲黄色成人网| 欧美午夜免费影院| 久久国产欧美精品| 亚洲人成免费| 欧美中文字幕在线| 亚洲伦理在线观看| 国际精品欧美精品| 欧美日韩高清在线观看| 欧美一级精品大片| 亚洲精品国产精品国自产在线| 欧美在线电影| av不卡在线看| 韩国av一区二区| 国产精品初高中精品久久| 久久久久久久综合狠狠综合| avtt综合网| 你懂的视频一区二区| 欧美一级黄色网| 亚洲午夜高清视频| 亚洲欧洲日本国产| 国产一区二区三区自拍| 欧美美女视频| 美女黄色成人网| 久久久91精品| 亚洲一区免费观看| 亚洲乱码精品一二三四区日韩在线| 久久久久综合| 欧美一区二区三区啪啪| 一本久久知道综合久久| 在线看片成人| 激情综合网址| 国产精品无人区| 欧美视频在线观看一区| 免费观看成人鲁鲁鲁鲁鲁视频| 久久99伊人| 亚洲午夜激情在线| 一本色道久久综合亚洲精品小说| 欧美激情第三页| 欧美国产日本韩| 女生裸体视频一区二区三区| 久久精品一本久久99精品| 午夜一级在线看亚洲| 亚洲男人的天堂在线| 亚洲午夜精品网| 亚洲一区免费在线观看| 亚洲视频一区二区在线观看| av成人激情| 99re热精品| 亚洲视屏一区| 亚洲欧美精品| 欧美一区午夜视频在线观看| 亚洲欧美区自拍先锋| 欧美一级精品大片| 久久久久久免费| 麻豆精品传媒视频| 亚洲第一综合天堂另类专| 亚洲国产99精品国自产| 亚洲国产成人久久综合| 亚洲茄子视频| 一区二区三区 在线观看视| 亚洲手机成人高清视频| 午夜欧美精品| 久久久久国产一区二区| 欧美国产成人在线| 欧美日韩一卡| 国产欧美日韩一区二区三区| 韩国av一区二区三区在线观看| 一区二区三区在线免费视频| 亚洲国产91色在线| 一本久久a久久免费精品不卡| 亚洲视频一区二区免费在线观看| 亚洲欧美在线x视频| 美女国产一区| 亚洲精品国产精品乱码不99| 中文一区二区在线观看| 欧美专区在线观看| 欧美粗暴jizz性欧美20| 欧美性猛交xxxx免费看久久久 | 欧美电影美腿模特1979在线看| 欧美日韩大陆在线| 国产欧美日韩免费看aⅴ视频| 亚洲福利视频免费观看| 一区二区三区欧美激情| 久久久精品国产免费观看同学| 免费亚洲一区二区| 夜夜爽www精品| 久久国产毛片| 欧美日韩综合另类| 伊大人香蕉综合8在线视| 一区二区三区欧美激情| 久久伊伊香蕉| 亚洲午夜91| 欧美国产亚洲另类动漫| 国产在线一区二区三区四区 | 国际精品欧美精品| 一区二区三区高清在线观看| 另类酷文…触手系列精品集v1小说| 亚洲区一区二| 玖玖精品视频| 狠狠色综合日日| 香蕉久久a毛片|