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

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

征名:

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

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

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

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

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

2. 難點分析

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

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

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

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

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

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

 A). 怎么查找?

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

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

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

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

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

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

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

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

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

 告訴你,沒有解決辦法!

 不過,我們要學會避開這些問題.比如,筆者做了一個可以根據(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掃描出來做好符號庫,進行簡單的自動完成...hahahaha

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

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

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

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

 說它比較麻煩,因為沒做過的都會有個直觀思路,就是掃描整個文件,然后放入數(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 閱讀(3077) 評論(26)  編輯 收藏 引用

只有注冊用戶登錄后才能發(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>
            亚洲国产另类 国产精品国产免费| 久久激五月天综合精品| 日韩视频在线一区二区| 在线播放日韩| 亚洲精品免费电影| av成人毛片| 亚洲影视九九影院在线观看| 亚洲摸下面视频| 亚洲永久免费视频| 久久成人精品视频| 欧美第十八页| 一区二区三区精品| 久久精品99国产精品日本| 欧美a级一区| 欧美天堂亚洲电影院在线播放| 欧美亚一区二区| 国模精品娜娜一二三区| 亚洲人成人99网站| 欧美影院成人| 亚洲第一精品电影| 99亚洲一区二区| 久久精品国产亚洲aⅴ| 欧美精品一区二区三区在线看午夜| 欧美三区视频| 亚洲福利视频免费观看| 亚洲欧美成aⅴ人在线观看| 麻豆精品在线视频| 亚洲视频日本| 欧美激情一区二区三区四区| 国产精品乱子乱xxxx| 亚洲国产精品一区在线观看不卡| 亚洲一区二区三区免费观看| 欧美 日韩 国产在线| 亚洲无亚洲人成网站77777| 男男成人高潮片免费网站| 国产毛片一区| 亚洲男人的天堂在线观看 | 亚洲精品一区二区三区99| 亚洲一区二区三区成人在线视频精品| av成人动漫| 欧美国产日产韩国视频| 亚洲一区视频| 欧美高清视频在线| 国产亚洲精品一区二555| 一本色道久久99精品综合| 欧美成人蜜桃| 久久久久九九九| 国产在线播精品第三| 欧美一区二区| 这里只有精品视频| 欧美日韩国产91| 最新成人av网站| 欧美韩日亚洲| 媚黑女一区二区| 亚洲国产人成综合网站| 欧美aⅴ一区二区三区视频| 午夜精品久久久久久久99黑人| 欧美日韩一区二区免费视频| 亚洲精品美女在线| 亚洲人成绝费网站色www| 免费在线日韩av| 亚洲欧洲精品一区二区精品久久久 | 欧美黄色免费网站| 久久综合久久综合久久综合| 激情亚洲网站| 欧美激情在线狂野欧美精品| 久久综合九色综合欧美狠狠| 一区二区在线免费观看| 美女性感视频久久久| 久久精品国产v日韩v亚洲| 国内外成人免费激情在线视频 | 在线一区视频| 国产精品久久久久久久久 | 亚洲高清资源综合久久精品| 久久人人九九| 亚洲精品日韩欧美| 亚洲精品之草原avav久久| 欧美日韩专区在线| 久久超碰97中文字幕| 久久婷婷麻豆| 一区二区三区产品免费精品久久75 | 性8sex亚洲区入口| 久久www成人_看片免费不卡| 亚洲第一精品夜夜躁人人爽| 亚洲国产成人av好男人在线观看| 欧美日韩精品| 久久久99国产精品免费| 免费成年人欧美视频| 亚洲欧美日韩电影| 久久免费偷拍视频| 一区二区欧美视频| 欧美在线free| 日韩视频―中文字幕| 欧美日韩专区在线| 亚洲性夜色噜噜噜7777| 亚洲欧美日韩精品久久亚洲区 | 国产精品日韩欧美一区二区| 久久综合久久美利坚合众国| 欧美黄色日本| 久久精品青青大伊人av| 欧美多人爱爱视频网站| 欧美一级久久| 嫩草国产精品入口| 性感少妇一区| 欧美日韩国产影片| 欧美福利视频在线| 国产午夜精品一区二区三区视频| 欧美大胆人体视频| 国产欧美日韩不卡免费| 亚洲欧洲美洲综合色网| 狠狠色狠狠色综合人人| 一区二区三区欧美在线观看| 亚洲国产精品电影在线观看| 亚洲综合99| 亚洲视频一二区| 欧美成人午夜激情| 老司机精品视频一区二区三区| 国产精品精品视频| 日韩视频永久免费| 亚洲理论在线| 免费视频一区二区三区在线观看| 久久精品国产亚洲一区二区三区| 欧美三日本三级三级在线播放| 欧美成人蜜桃| 伊人夜夜躁av伊人久久| 午夜伦欧美伦电影理论片| 亚洲综合视频一区| 欧美日韩中文字幕| 一本到12不卡视频在线dvd| 亚洲精品乱码久久久久久按摩观| 久久精品一区二区三区中文字幕 | 亚洲六月丁香色婷婷综合久久| 欧美一区二区免费| 欧美在线黄色| 国产亚洲成年网址在线观看| 亚洲欧美怡红院| 欧美一区二区三区在线免费观看| 欧美日韩情趣电影| 99热在线精品观看| 亚洲欧美日韩一区二区三区在线| 国产精品成人va在线观看| 一本久道久久久| 亚洲综合精品四区| 国产乱码精品1区2区3区| 午夜精品久久久久久久久久久 | 亚洲精品一品区二品区三品区| 亚洲国产精品成人va在线观看| 久久综合久久综合久久综合| 欧美va亚洲va国产综合| 91久久在线播放| 欧美日韩一级黄| 亚洲伊人色欲综合网| 久久精品国产第一区二区三区最新章节| 国产精品视频免费| 美女视频黄免费的久久| 女女同性精品视频| 亚洲人成亚洲人成在线观看| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久久欧美一区二区| 亚洲第一黄色| 欧美日韩中文字幕日韩欧美| 亚洲欧美国产精品专区久久| 久久精品视频在线| 亚洲激情婷婷| 国产精品黄色在线观看| 欧美在线不卡视频| 亚洲精品日韩在线| 午夜一区二区三区在线观看| 国产亚洲精品久久久久婷婷瑜伽| 久久亚洲精品一区二区| 亚洲日韩中文字幕在线播放| 亚洲欧美久久| 极品尤物久久久av免费看| 欧美久久久久久久| 欧美一区二区精品在线| 亚洲日本中文字幕| 久久蜜臀精品av| 一区二区三区四区五区精品视频| 国产无遮挡一区二区三区毛片日本| 老鸭窝91久久精品色噜噜导演| 日韩视频在线一区二区| 久久综合一区二区三区| 亚洲综合欧美日韩| 亚洲精品社区| 国产在线视频欧美| 欧美日韩系列| 免费久久99精品国产自在现线| 亚洲四色影视在线观看| 欧美成年网站| 久久久噜噜噜| 欧美一区成人| 中国成人亚色综合网站| 136国产福利精品导航网址应用| 国产精品99一区二区| 欧美激情精品久久久| 久久久久久亚洲精品不卡4k岛国| 夜夜嗨一区二区三区| 亚洲精品美女91| 亚洲国产导航| 欧美黄免费看|