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

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

征名:

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

正文:
-------------------------------------------------------------------------------------
1. 什么是代碼自動(dòng)完成1

  首先我們先來(lái)下個(gè)定義.不要小瞧這個(gè),沒(méi)有這個(gè)定義,我們很容易迷失在功能的海洋之中.所謂代碼自動(dòng)完成既是

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

  注意:我們?cè)谶@里用了[事先準(zhǔn)備好]這個(gè)詞.

2. 難點(diǎn)分析

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

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

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

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

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

 那么上面的幾個(gè)難點(diǎn)就迎刃而解了.我們來(lái)看一下.

 A). 怎么查找?

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

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

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

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

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

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

 因?yàn)槭褂昧藬?shù)據(jù)庫(kù),所以只顯示頭幾條就可以了.當(dāng)然可以分頁(yè)顯示全部拉.因?yàn)閟qlite支持limit語(yǔ)句.

 到了這兒,我們可以知道上面的幾個(gè)難點(diǎn)都不是難點(diǎn)了,甚至很Easy.

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

 告訴你,沒(méi)有解決辦法!

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

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

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

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

 效果不錯(cuò)哦~~~`

 采用上面的做法,你可以想SourceInsight那樣,把一個(gè)庫(kù),或者整個(gè)windows sdk掃描出來(lái)做好符號(hào)庫(kù),進(jìn)行簡(jiǎn)單的自動(dòng)完成...hahahaha

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

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

 2)上面說(shuō)的都是事先準(zhǔn)備好的表. 3)所提及的則是根據(jù)該文件要?jiǎng)討B(tài)生成的表.

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

 說(shuō)它比較麻煩,因?yàn)闆](méi)做過(guò)的都會(huì)有個(gè)直觀思路,就是掃描整個(gè)文件,然后放入數(shù)據(jù)庫(kù)中就完事了啊.

 其實(shí)不然,直接掃描時(shí)最偷懶的做法,也是最有效的.
 
 在這里,我給一個(gè)簡(jiǎn)單的解決方案,不過(guò)還沒(méi)沒(méi)來(lái)得及去寫(xiě).

 方案如下:

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

 文字就是我們要可能自動(dòng)完成的詞匯.

 這樣,我們?cè)诜治龅臅r(shí)候,只要把[ 詞匯->文件->代碼行 ]這樣的信息存入到指定的表中,就可以了.甚至只存入詞即可。

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

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

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

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

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

 后記,我曾經(jīng)做了一個(gè)sample,后來(lái)?yè)Q電腦了,就不知道弄哪去了。
posted on 2011-01-04 20:21 megax 閱讀(3077) 評(píng)論(26)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            免费成人高清在线视频| 欧美日韩福利视频| 久久免费一区| 麻豆成人在线观看| 欧美国产大片| 欧美日韩高清不卡| 欧美天天影院| 欧美午夜精品久久久久久超碰| 欧美三级视频| 国产热re99久久6国产精品| 国产欧美一区二区精品忘忧草| 国产综合香蕉五月婷在线| 激情久久久久久久| 91久久精品久久国产性色也91| 亚洲三级视频| 亚洲一区高清| 久久免费一区| 欧美激情精品久久久久久大尺度 | 欧美日本国产视频| 欧美午夜美女看片| 国产小视频国产精品| 亚洲第一黄网| 中文在线资源观看视频网站免费不卡| 亚洲一区二区精品视频| 久久精品99无色码中文字幕| 久久综合中文| 亚洲精品在线免费| 午夜精品久久久久久久蜜桃app| 久久精品免费电影| 欧美国产精品人人做人人爱| 欧美性色aⅴ视频一区日韩精品| 国产一区二区三区在线观看视频 | 欧美日韩国产成人高清视频| 国产精品美女xx| 亚洲国产成人av在线| 亚洲午夜激情网站| 久久久亚洲综合| 亚洲国产精品久久久久婷婷884| 在线综合亚洲欧美在线视频| 久久成人久久爱| 欧美日韩第一区| 国内精品视频一区| 亚洲午夜激情| 欧美暴力喷水在线| 亚洲一区黄色| 欧美成人一区二区| 国产伦精品一区二区三区高清| 亚洲欧洲精品一区二区三区| 欧美在线日韩在线| 亚洲精品一区二区三区av| 久久av一区二区三区| 欧美日韩亚洲国产一区| 在线电影欧美日韩一区二区私密| 亚洲天堂第二页| 欧美激情成人在线视频| 性久久久久久久久| 欧美视频一区二| 亚洲黄色av一区| 久久免费一区| 亚洲永久在线观看| 欧美日韩国产一区二区三区| 亚洲高清久久| 久久精品女人天堂| 中文亚洲视频在线| 欧美美女视频| 亚洲国产精品免费| 久久一区二区视频| 亚洲欧美日韩网| 欧美视频在线免费| 亚洲精品影院在线观看| 噜噜噜在线观看免费视频日韩| 亚洲欧美一区二区视频| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 韩国av一区二区三区四区| 亚洲综合精品一区二区| 最新亚洲电影| 欧美a级理论片| 亚洲国产1区| 欧美成人精品高清在线播放| 久久成人国产| 国内精品视频666| 久久久久久免费| 欧美一区二区三区的| 国产精品一区二区久久| 小黄鸭精品aⅴ导航网站入口| 99精品国产热久久91蜜凸| 欧美精品在线看| 99av国产精品欲麻豆| 91久久精品美女| 欧美激情第二页| 99re热精品| 日韩视频不卡中文| 欧美先锋影音| 亚洲永久精品国产| 亚洲一区二区三区777| 国产精品视频不卡| 欧美一区2区三区4区公司二百| 亚洲一区三区电影在线观看| 国产精品免费一区二区三区在线观看 | 国语自产精品视频在线看抢先版结局 | 一区二区日韩精品| 欧美日韩视频一区二区三区| 一区二区三区波多野结衣在线观看| 亚洲人体大胆视频| 欧美三级视频| 午夜在线成人av| 亚洲永久精品国产| 国产日韩欧美三级| 久久这里有精品15一区二区三区| 久久久久久香蕉网| 亚洲人成网在线播放| 亚洲欧洲日韩在线| 欧美亚州一区二区三区| 欧美一区二区三区免费大片| 欧美一区观看| 亚洲国产精品久久久久秋霞蜜臀 | 99国产精品久久久久久久成人热| 欧美日韩中文另类| 性欧美大战久久久久久久久| 欧美一区二区精品久久911| 一区二区三区在线看| 亚洲国产精品v| 国产精品magnet| 久久久女女女女999久久| 老司机aⅴ在线精品导航| 日韩网站在线看片你懂的| 一区二区成人精品 | 亚洲国产成人在线视频| 欧美日韩在线一区| 久久福利视频导航| 欧美freesex8一10精品| 亚洲欧美日韩国产一区| 久久精品在线播放| 99在线热播精品免费| 亚洲一区二区三区四区五区黄 | 亚洲免费播放| 国产一区在线看| 亚洲精品乱码| 国产一区二区三区在线观看网站 | 欧美精品激情blacked18| 亚洲欧美视频| 美女视频一区免费观看| 亚洲欧美一区二区激情| 久久在线免费| 亚洲欧美日韩一区在线| 久久影视精品| 欧美一区二区视频97| 免费日韩成人| 欧美一区免费视频| 欧美激情精品久久久久久黑人| 欧美影院在线播放| 欧美激情精品久久久| 久久久久成人精品免费播放动漫| 欧美精品二区三区四区免费看视频| 久久国产直播| 欧美日韩一本到| 欧美成人午夜激情在线| 国产精品尤物| 日韩一区二区电影网| 亚洲丁香婷深爱综合| 亚洲综合第一页| 一区二区三区精品国产| 久久久久亚洲综合| 欧美与黑人午夜性猛交久久久| 欧美激情久久久久| 麻豆成人精品| 国产偷国产偷亚洲高清97cao| 99亚洲精品| 最新中文字幕亚洲| 久久精品亚洲一区| 欧美在线观看一二区| 欧美日韩亚洲系列| 亚洲国产成人在线| 亚洲丶国产丶欧美一区二区三区| 午夜视频在线观看一区| 亚洲综合色噜噜狠狠| 欧美日本在线观看| 亚洲高清在线观看| 亚洲国产成人tv| 久久久久成人网| 久久久精品一区二区三区| 国产久一道中文一区| 亚洲视频精选在线| 中日韩午夜理伦电影免费| 欧美大片第1页| 亚洲风情亚aⅴ在线发布| 亚洲电影免费观看高清完整版在线 | 免费成人黄色片| 韩国精品一区二区三区| 欧美一区激情| 久久精品国产一区二区电影 | 久久久久88色偷偷免费| 久久精品毛片| 国产欧美综合一区二区三区| 亚洲网站在线| 欧美一区二区久久久| 国产模特精品视频久久久久 | 日韩天堂av| 欧美精品一区二区在线观看| 亚洲欧洲一区二区在线观看|