• <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>
            posts - 76,  comments - 621,  trackbacks - 0
            首先說,這篇文章是很久很久很久以前寫的,后來覺得沒啥技術(shù)含量,就沒發(fā)。今天放到這兒賺個眼球,主要目的還是征名,CPPBLOG網(wǎng)友一定要給力哦!

            征名:

            1. LiteEdit
            2. EditLite
            3. EverEdit
            4. EditWin
            5. MegaxEdit

            正文:
            -------------------------------------------------------------------------------------
            1. 什么是代碼自動完成1

              首先我們先來下個定義.不要小瞧這個,沒有這個定義,我們很容易迷失在功能的海洋之中.所謂代碼自動完成既是

              在用戶輸入或者修改的時候,能夠根據(jù)光標(biāo)前后位置的文本信息, 從[事先準(zhǔn)備好]的查找表中找出最匹配的過程.

              注意:我們在這里用了[事先準(zhǔn)備好]這個詞.

            2. 難點分析

             A). 怎么查找?
             B). 從什么樣的表中查找?
             C). 內(nèi)存占用怎么樣?
             D). 如何快速的顯示出最匹配的結(jié)果?

             我想上面的幾個問題是大多數(shù)人的第一印象.確實,在我做這項工作之前,我嘗試了寫了幾個數(shù)據(jù)結(jié)構(gòu)來表達(dá)這樣的操作.

             什么三叉,二叉樹啊,可是最后發(fā)現(xiàn)都比較麻煩。

             不過,這些嘗試讓我覺得我寫的東西像個東西...什么呢? 這不就是個數(shù)據(jù)庫查詢嘛!!

             經(jīng)過一番周折(其間過程不述), 選用了sqlite3作為數(shù)據(jù)庫,關(guān)于sqlite3是什么,本文不作具體描述.

             那么上面的幾個難點就迎刃而解了.我們來看一下.

             A). 怎么查找?

             這個就簡單多啦, select * from table where keyword like 'hint%', 其中的hint就是用戶輸入或者修改的前后文文本信息.

             B). 從什么樣的查找表中查找?

             不管了,當(dāng)然是數(shù)據(jù)庫.

             C). 內(nèi)存占用怎么樣?

             這個....我測試,一個表里面5萬條數(shù)據(jù),嵌入到程序之中后,內(nèi)存增加2M-3M左右.

             D). 如何快速的顯示出最匹配的結(jié)果?

             因為使用了數(shù)據(jù)庫,所以只顯示頭幾條就可以了.當(dāng)然可以分頁顯示全部拉.因為sqlite支持limit語句.

             到了這兒,我們可以知道上面的幾個難點都不是難點了,甚至很Easy.

             不過,有一個問題,加入數(shù)據(jù)庫當(dāng)中有好幾萬條甚至數(shù)十萬條,那么怎么辦呢?

             告訴你,沒有解決辦法!

             不過,我們要學(xué)會避開這些問題.比如,筆者做了一個可以根據(jù)用戶的輸入即時提示用戶可能輸入的單詞的Sample,包含常用的單詞,分詞,復(fù)數(shù),大約有10萬個左右吧.

             在我的程序中,甚至Debug版本中,都可以即時的顯示出來,不管你輸入多塊,還有一點就是內(nèi)存占用只增加了幾百K. Why?

             呵呵,其實很簡單,我創(chuàng)建了26張表. 聰明的讀者應(yīng)該馬上猜到了, 開頭為a的單詞放到一張表,開頭為b的單詞放到另一張表,其實就是一個簡單的hash,寫查詢的時候,這樣.

             sprintf( sql, "select word from %c_wordlist where word like '%s%%' limit 0, 10", buf[0], buf );

             效果不錯哦~~~`

             采用上面的做法,你可以想SourceInsight那樣,把一個庫,或者整個windows sdk掃描出來做好符號庫,進(jìn)行簡單的自動完成...hahahaha

             選用數(shù)據(jù)庫的最大的優(yōu)點是可擴(kuò)展性極佳.

            3).比較麻煩的一點: 如何完成文件內(nèi)的詞匯?

             2)上面說的都是事先準(zhǔn)備好的表. 3)所提及的則是根據(jù)該文件要動態(tài)生成的表.

             其實上面兩者都是事先準(zhǔn)備好的表,只不過一個狹義的,一個是廣義的而已.

             說它比較麻煩,因為沒做過的都會有個直觀思路,就是掃描整個文件,然后放入數(shù)據(jù)庫中就完事了啊.

             其實不然,直接掃描時最偷懶的做法,也是最有效的.
             
             在這里,我給一個簡單的解決方案,不過還沒沒來得及去寫.

             方案如下:

             在做詞法分析的時候,我們都會分析出來一些既不是關(guān)鍵字也不是字符串或者其它的state的[單純的文字].....懂了嗎?這些單純的

             文字就是我們要可能自動完成的詞匯.

             這樣,我們在分析的時候,只要把[ 詞匯->文件->代碼行 ]這樣的信息存入到指定的表中,就可以了.甚至只存入詞即可。

             添加行或者刪除行的時候,更新該表就可以了.

             在顯示的時候,因為一個文件可能關(guān)聯(lián)好幾個自動完成Database,那么設(shè)定好優(yōu)先級,本文件內(nèi)的很顯然具有最高優(yōu)先級.其它要么顯示

             要么不顯示.要么只在注釋中顯示.....

             每隔一段時間就掃描一次文件,如果文件不是太大的話,效率應(yīng)該不錯。

            -----------------------------------------------------------------------

             后記,我曾經(jīng)做了一個sample,后來換電腦了,就不知道弄哪去了。
            posted on 2011-01-04 20:21 megax 閱讀(3024) 評論(26)  編輯 收藏 引用

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


            日韩人妻无码一区二区三区久久99| 无码伊人66久久大杳蕉网站谷歌| 欧美亚洲国产精品久久高清| 亚洲狠狠综合久久| 久久久国产精品| 久久久午夜精品| 久久se精品一区精品二区| 国产精品99精品久久免费| 久久婷婷久久一区二区三区| 7777精品伊人久久久大香线蕉| 久久国产欧美日韩精品| 久久久WWW成人免费毛片| 精品综合久久久久久98| 色综合久久综精品| 一本色道久久综合狠狠躁| 欧美大战日韩91综合一区婷婷久久青草 | 久久天堂AV综合合色蜜桃网| 久久99久久无码毛片一区二区| 国产成人综合久久精品红| 久久国产精品无码一区二区三区| 伊人久久大香线蕉亚洲| 国内精品久久久久久久久| 久久久久久九九99精品| 亚洲欧洲精品成人久久曰影片| 久久综合久久综合久久综合| 亚洲精品无码久久久久去q| 久久精品成人欧美大片| 国产精品久久久久久搜索| 国产精品一久久香蕉产线看| 波多野结衣久久一区二区| 亚洲欧美日韩精品久久| 久久精品国产亚洲综合色| 久久综合给合久久狠狠狠97色69| 亚洲国产成人精品女人久久久 | 伊人久久大香线蕉av一区| 欧美激情精品久久久久久久九九九| 日产精品99久久久久久| 99久久精品国产一区二区| 久久免费国产精品| 久久精品成人欧美大片| 久久久受www免费人成|