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

www.myuml.net

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

2009年11月4日 #

因為買的東西很多,把84消毒液放在了衣服袋子里,結果,新買的衣服成了白一塊、黑一塊。。。。。。

 

結論:84消毒液太強勁了,將衣服上的顏色都刷掉了。

posted @ 2009-11-04 16:43 尋舟 閱讀(234) | 評論 (0)編輯 收藏

2009年10月29日 #

以前讀書的時候整過Foxbase,FoxPro,及微軟公司那時讓我覺得非常強大的Visual Foxpro 6.0。盡管我有大概十年的時候沒有碰過Visual Foxpro了,但這并不妨礙我認為Visual Foxpro開發界面之友好程度。
 
后來畢業了,整過微軟的SQL Server,以及免費的mysql。
 
從軟件設計的角度來看,ORACLE數據庫近乎完美。設計周密,性能方面做到了極致的考慮。有時我覺得我整Oracle是被迫的。但是不得不承認,給我的印象是驚為天人,
 
 
posted @ 2009-10-29 12:38 尋舟 閱讀(271) | 評論 (0)編輯 收藏

2009年10月28日 #

今天要休息了,應該是這幾天最早休息的一個晚上吧。

posted @ 2009-10-28 23:52 尋舟 閱讀(263) | 評論 (0)編輯 收藏

2009年10月27日 #

如何設計一個應用軟件

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

這六種技術構成了各種各樣新技術的根基。

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

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

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

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

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

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

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

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

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

二、應用軟件的內核:對象或者數據結構+算法
很顯然,面向對象相對于面向過程更適用于寫應用軟件。
這里涉及到主要問題是應用軟件應該采用怎么樣的對象來表達對應的文檔。

注意在此時,我們的應用程序還沒有任何圖形化的界面。我們希望能做的內核能夠達到這樣的要求就行了:在測試程序中,說的通俗一點,就是我們寫一個main函數,然后在該函數中,我們可以創建一個對象,然后調用該對象的各種方法,跟蹤其方法,查看是否能夠實現要求。

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

三、應用軟件的文檔:文件、文件格式、文件保存及讀取。

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

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

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

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

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

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

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

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

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

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

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

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

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

posted @ 2009-10-27 00:55 尋舟 閱讀(2415) | 評論 (14)編輯 收藏

2009年10月26日 #

查看Qt4的一些示例項目的時候,使用設計器打開其UI文件,在文件中竟然找不到signal和slot的連接。但是最終的程序,slot卻又能準確的響應信號。打開通過ui文件自動生成的c++文件,其中也找不到connect語句,到底是怎么一回事?

經過逐語句的分析。終于發現連接的原因就在于setUi函數的最后一句

QMetaObject::connectSlotsByName(MainWindow);

找到該靜態函數

void QMetaObject::connectSlotsByName(QObject *o)
{
    if (!o)
        return;
    const QMetaObject *mo = o->metaObject();
    Q_ASSERT(mo);
    const QObjectList list = qFindChildren<QObject *>(o, QString());
    for (int i = 0; i < mo->methodCount(); ++i) {

/*

slot是方法的名字,在以下的內容中,會把它分成三部分(依次判斷該方法是否滿足這三部分的條件):

第一部分:on_

第二部分:子對象名

第三部分:信號名

*/
        const char *slot = mo->method(i).signature();
        Q_ASSERT(slot);

//以下一行用來判斷slot的前三位是否是on_,如果不是,就跳過這個方法。
        if (slot[0] != 'o' || slot[1] != 'n' || slot[2] != '_')
            continue;
        bool foundIt = false;

//遍歷子對象。
        for(int j = 0; j < list.count(); ++j) {
            const QObject *co = list.at(j);

//得到子對象名。
            QByteArray objName = co->objectName().toAscii();
            int len = objName.length();

//要求slot跳過前3位(on_)后,接下來的子字符串和子對象名相同,并且接著該子字符串又是一個_

//如果達不到這個要求,continue
            if (!len || qstrncmp(slot + 3, objName.data(), len) || slot[len+3] != '_')
                continue;
            const QMetaObject *smo = co->metaObject();
            int sigIndex = smo->indexOfMethod(slot + len + 4);
            if (sigIndex < 0) { // search for compatible signals
                int slotlen = qstrlen(slot + len + 4) - 1;

//搜索該子對象所能引發的信號
                for (int k = 0; k < co->metaObject()->methodCount(); ++k) {
//方法類型如果符合要求

                    if (smo->method(k).methodType() != QMetaMethod::Signal)
                        continue;

//如果slot最后的子字符串和信號名相同

                    if (!qstrncmp(smo->method(k).signature(), slot + len + 4, slotlen)) {
                        sigIndex = k;
                        break;
                    }
                }
            }
            if (sigIndex < 0)
                continue;

//連接操作
            if (QMetaObject::connect(co, sigIndex, o, i)) {
                foundIt = true;
                break;
            }
        }

//連接成功
        if (foundIt) {
            // we found our slot, now skip all overloads
            while (mo->method(i + 1).attributes() & QMetaMethod::Cloned)
                  ++i;
        }

//連接失敗

else if (!(mo->method(i).attributes() & QMetaMethod::Cloned)) {
            qWarning("QMetaObject::connectSlotsByName: No matching signal for %s", slot);
        }
    }
}

得出此結論:自動生成的文件中,該函數總會存在setUi函數的最后一句。

該函數的作用就是尋找setUi的唯一指針參數MainWindow所指向對象的成員函數,

該成員函數的名字如果滿足以下條件,就做連接操作。

函數名規則:on_子對象名_信號名

函數簽名(即返回值與參數要符合slot要求)

所以,我們可以這樣做:在qt設計器中添加按紐或者菜單項或者按紐項后,不用在設計器中手動做連接操作。

我們只要在主窗口類中添加符合條件的成員函數即可。

函數名規則:on_子對象名_信號名

函數簽名(即返回值與參數要符合slot要求)

例如:

在設計器中添加一個菜單項,其對應的action為actionNew

那么在主窗口類中添加以下的函數

public slots:

       void on_actionNew_triggered();

當切換這個菜單時,會自動執行上面的成員函數。

posted @ 2009-10-26 13:11 尋舟 閱讀(2385) | 評論 (0)編輯 收藏

僅列出標題  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美国产一区二区三区| 欧美美女bb生活片| 欧美在线啊v一区| 一区二区免费在线视频| 日韩天天综合| 一本大道久久a久久综合婷婷| 亚洲福利国产精品| 亚洲人成人99网站| 99精品免费| 亚洲午夜精品国产| 久久精品国产一区二区电影| 久久综合狠狠综合久久综青草| 久久综合伊人77777麻豆| 欧美好骚综合网| 亚洲国产日韩一区| 一本色道久久综合亚洲精品婷婷| 亚洲影音先锋| 久久综合久久久| 欧美日韩国产三级| 国产精品视频专区| 亚洲电影下载| 亚洲尤物在线视频观看| 久久九九精品99国产精品| 美女露胸一区二区三区| 91久久精品国产91久久性色tv| 夜夜爽av福利精品导航| 欧美影院久久久| 欧美精品xxxxbbbb| 国内精品**久久毛片app| 亚洲毛片在线观看.| 久久精品一区| 亚洲最黄网站| 蜜桃av噜噜一区二区三区| 国产精品日韩欧美| 亚洲美女av电影| 久久亚洲欧美| 亚洲一区二区三区成人在线视频精品| 另类专区欧美制服同性| 国产精品蜜臀在线观看| 亚洲国产精品一区二区第四页av| 性做久久久久久久久| 亚洲欧洲一区二区三区久久| 久久精品国产久精国产一老狼| 欧美三级日韩三级国产三级| 久久精品国产久精国产思思| 久久精品国产69国产精品亚洲| 美女久久一区| 欧美一区三区二区在线观看| 欧美日韩中文在线| 日韩视频精品在线| 欧美大片在线观看一区| 欧美在线中文字幕| 国产精品免费在线| 亚洲午夜精品久久久久久浪潮| 欧美激情视频一区二区三区在线播放| 亚洲欧美日韩国产一区二区| 欧美日韩国产综合视频在线观看中文 | 久久一区二区三区四区| 中文精品在线| 欧美激情一区在线观看| 亚洲精品老司机| 欧美黄色精品| 免费欧美日韩| 亚洲黄色免费| 欧美激情精品久久久久久免费印度 | 国产午夜精品久久久久久免费视| 正在播放欧美一区| 99视频+国产日韩欧美| 欧美激情中文不卡| 一本久久a久久精品亚洲| 亚洲日本国产| 欧美日韩在线播放三区四区| 在线亚洲观看| 亚洲一区日本| 国产一区二区欧美| 久久综合久久美利坚合众国| 久久久噜噜噜久久中文字幕色伊伊| 一区二区三区在线高清| 久久综合九色欧美综合狠狠| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲电影有码| 欧美午夜一区| 久久大香伊蕉在人线观看热2| 久久av红桃一区二区小说| 亚洲国产精品久久久久秋霞蜜臀 | 久久99伊人| 亚洲国产精品va| 亚洲精品一区二区三| 国产乱码精品一区二区三区不卡| 久久久久久欧美| 欧美多人爱爱视频网站| 亚洲在线观看| 欧美在线啊v一区| 亚洲免费观看高清在线观看| 亚洲天堂男人| 在线精品在线| 欧美日韩精品一区二区| 在线免费观看日韩欧美| 亚洲精品久久久久久下一站 | 久久久亚洲成人| 亚洲免费精彩视频| 亚洲欧美视频在线| 亚洲精品久久久蜜桃| 亚洲深夜影院| 亚洲国产另类久久精品| 亚洲视频精选| 亚洲精品欧洲| 欧美有码视频| 亚洲欧美bt| 欧美精品免费在线观看| 久久九九全国免费精品观看| 欧美精品久久99| 久久亚洲风情| 国产精品视频福利| 亚洲精品日本| 在线精品高清中文字幕| 亚洲男人影院| 亚洲一区二区精品| 欧美**人妖| 美日韩免费视频| 国产老肥熟一区二区三区| 日韩午夜电影在线观看| 亚洲欧洲免费视频| 久久人人97超碰国产公开结果| 欧美亚洲综合网| 欧美日韩在线不卡| 亚洲美女av黄| 日韩一级二级三级| 麻豆视频一区二区| 欧美成人免费视频| 极品尤物一区二区三区| 欧美伊人久久久久久午夜久久久久| 亚洲一区中文字幕在线观看| 欧美日韩一级黄| 日韩亚洲视频在线| 9l国产精品久久久久麻豆| 免费在线欧美视频| 欧美大片免费观看| 亚洲国产高清在线观看视频| 你懂的国产精品| 欧美国产第一页| …久久精品99久久香蕉国产| 久久婷婷国产综合尤物精品 | 在线精品亚洲| 久久久久久尹人网香蕉| 久久人人爽人人爽爽久久| 国产一区二区三区网站| 久久久av网站| 欧美福利小视频| 亚洲精品久久视频| 欧美精品一线| 正在播放亚洲| 久久精品国产成人| 在线不卡中文字幕| 91久久精品国产91性色tv| 一本久道久久综合中文字幕| 欧美日韩免费一区| 亚洲综合日韩中文字幕v在线| 久久国产精品一区二区三区四区 | 99精品国产高清一区二区| 欧美日本免费一区二区三区| 日韩西西人体444www| 性久久久久久| 伊人夜夜躁av伊人久久| 欧美成人免费大片| 在线视频日韩| 久久久综合精品| 亚洲欧洲美洲综合色网| 国产精品99一区二区| 午夜精品一区二区三区在线视 | 激情懂色av一区av二区av| 免费观看久久久4p| 在线亚洲免费| 免费观看一级特黄欧美大片| 亚洲巨乳在线| 国产伦精品一区二区三| 久久视频精品在线| 中文精品一区二区三区| 免费观看欧美在线视频的网站| 一区二区欧美日韩视频| 国产视频综合在线| 欧美风情在线| 久久国产精品72免费观看| 亚洲精品国产精品国自产在线 | 国产麻豆一精品一av一免费| 久久永久免费| 亚洲男人av电影| 亚洲二区视频在线| 久久精品亚洲一区二区| 国产精品99久久99久久久二8 | 欧美99在线视频观看| 亚洲欧美日韩一区在线观看| 欧美福利电影在线观看| 午夜欧美不卡精品aaaaa| 91久久精品一区| 国产视频在线观看一区| 欧美日韩中文字幕日韩欧美| 久热国产精品视频| 欧美在线视频免费|