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

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

征名:

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

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

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

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

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

2. 難點分析

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

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

 什么三叉,二叉樹啊,可是最后發現都比較麻煩。

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

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

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

 A). 怎么查找?

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

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

 不管了,當然是數據庫.

 C). 內存占用怎么樣?

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

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

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

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

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

 告訴你,沒有解決辦法!

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

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

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

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

 效果不錯哦~~~`

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

 選用數據庫的最大的優點是可擴展性極佳.

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

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

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

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

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

 方案如下:

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

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

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

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

 在顯示的時候,因為一個文件可能關聯好幾個自動完成Database,那么設定好優先級,本文件內的很顯然具有最高優先級.其它要么顯示

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

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

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

 后記,我曾經做了一個sample,后來換電腦了,就不知道弄哪去了。
posted on 2011-01-04 20:21 megax 閱讀(3060) 評論(26)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧洲精品一区二区三区| 欧美另类变人与禽xxxxx| 国产精品私人影院| 欧美一区二区女人| 欧美一区二区视频在线观看2020| 国产视频在线观看一区二区| 欧美在线视频播放| 麻豆精品传媒视频| 国产精品99久久久久久有的能看| 亚洲视频网在线直播| 国语自产精品视频在线看抢先版结局 | 久久九九免费| 亚洲精品在线电影| 欧美福利小视频| 亚洲国产一区二区精品专区| 久久精品成人一区二区三区| 性欧美xxxx视频在线观看| 激情视频一区| 亚洲免费在线观看视频| 亚洲精品欧美日韩专区| 午夜精品久久久久99热蜜桃导演| 在线观看91精品国产入口| 亚洲午夜伦理| 亚洲免费在线电影| 欧美人与性动交cc0o| 免费一区二区三区| 影音先锋在线一区| 久久成人免费网| 久久av一区二区三区亚洲| 国产精品女人久久久久久| 亚洲黑丝一区二区| 亚洲精选91| 欧美色欧美亚洲另类二区 | 性色av一区二区三区红粉影视| 亚洲黄色免费电影| 欧美激情1区2区3区| 亚洲福利小视频| 日韩亚洲欧美中文三级| 欧美精品videossex性护士| 欧美国产日韩一区| 日韩亚洲欧美成人| 欧美大片国产精品| 亚洲精品欧美在线| 欧美日韩精品免费观看视频| 亚洲视频福利| 蜜桃久久精品乱码一区二区| 亚洲欧洲日本一区二区三区| 欧美人体xx| 久久午夜视频| 亚洲一区二区黄| 久久综合九色九九| 亚洲婷婷免费| 一区二区三区在线视频播放 | 国内精品视频在线观看| 久久琪琪电影院| 亚洲一级黄色av| 亚洲国产精品电影在线观看| 久久成人在线| 亚洲一区二区三区四区五区午夜 | 亚洲日本黄色| 国产在线观看91精品一区| 欧美日韩国产影院| 乱人伦精品视频在线观看| 亚洲免费视频一区二区| 91久久在线观看| 亚洲激情图片小说视频| 久久久亚洲欧洲日产国码αv | 一区二区亚洲精品国产| 国产精品午夜久久| 国产精品女人毛片| 欧美日韩一卡二卡| 欧美午夜视频一区二区| 欧美人成网站| 国产精品久久久久久模特| 亚洲国产精品va在线看黑人| 久久九九99视频| 久久免费高清| 欧美电影打屁股sp| 亚洲三级视频在线观看| 一区二区三区www| 亚洲天堂av在线免费| 亚洲在线第一页| 久久精品观看| 欧美日韩国产精品成人| 国产精品毛片大码女人| 国语自产精品视频在线看抢先版结局 | 亚洲国产成人精品久久久国产成人一区| 久久免费国产精品| 亚洲另类在线视频| 欧美伊人久久久久久午夜久久久久 | 亚洲国产高清一区二区三区| 亚洲免费观看在线观看| 午夜激情综合网| 欧美日韩亚洲三区| 激情久久久久久久久久久久久久久久| 亚洲国产一区在线观看| 欧美在线观看一区二区| 亚洲免费av观看| 免费视频最近日韩| 国产色产综合色产在线视频| 一区二区三区四区五区在线 | 亚洲午夜小视频| 欧美寡妇偷汉性猛交| 欧美亚洲综合另类| 国产精品国产馆在线真实露脸| 亚洲精品国产精品国自产观看| 欧美中文字幕精品| 亚洲视频在线观看视频| 亚洲成人在线免费| 久久久久久亚洲精品杨幂换脸 | 99国产精品久久久久久久久久 | 亚洲欧美精品中文字幕在线| 欧美电影电视剧在线观看| 久久综合电影| 亚洲国产精品第一区二区| 猛男gaygay欧美视频| 久久精品色图| 日韩午夜电影在线观看| 亚洲日本欧美日韩高观看| 欧美精品综合| 亚洲男人的天堂在线aⅴ视频| 一本色道久久综合| 国产精品亚洲第一区在线暖暖韩国| 午夜国产欧美理论在线播放| 香蕉久久夜色| 亚洲美女精品久久| 亚洲先锋成人| 91久久久在线| 亚洲欧美精品suv| 亚洲精品男同| 久久国产乱子精品免费女| 最近中文字幕日韩精品| 亚洲午夜激情网页| 亚洲精品一区二区三区99| 亚洲一区二区三区欧美| 亚洲激情视频在线播放| 亚洲午夜精品久久久久久app| 在线播放日韩| 午夜精品久久久久久99热| 在线亚洲伦理| 亚洲人成网站色ww在线| 有码中文亚洲精品| 午夜伦理片一区| 亚洲综合第一| 欧美精品在线视频| 亚洲日本一区二区三区| 91久久精品国产91久久性色| 久久免费少妇高潮久久精品99| 欧美一区二粉嫩精品国产一线天| 欧美精品麻豆| 99精品欧美一区| 欧美亚洲视频在线观看| 国产精品老牛| 欧美一区亚洲| 免费观看一区| 一区二区三区日韩精品视频| 欧美黄污视频| 亚洲欧美国产日韩天堂区| 久久手机免费观看| 最近中文字幕mv在线一区二区三区四区 | 亚洲视频 欧洲视频| 国产精品女主播| 午夜一区在线| 最新亚洲一区| 久久久久.com| av成人毛片| 国产欧美日韩综合一区在线观看 | 欧美 日韩 国产在线 | 99视频在线精品国自产拍免费观看| 99在线精品观看| 一区二区三区在线免费视频| 欧美电影资源| 久久精品一本| 亚洲在线网站| 一区二区三区四区五区精品| 毛片一区二区三区| 亚洲欧美日本在线| 亚洲精品国久久99热| 国产日韩在线不卡| 国产精品青草久久久久福利99| 麻豆精品91| 久久香蕉精品| 久久精品一区二区三区四区| 亚洲欧美日本国产有色| 亚洲精品欧美极品| 亚洲欧洲精品一区二区| 影音先锋久久久| 狠狠入ady亚洲精品| 国产一区日韩欧美| 国产一区视频在线观看免费| 国产女主播一区二区| 国产精品久久9| 国产婷婷97碰碰久久人人蜜臀| 国产精品扒开腿做爽爽爽视频 | 这里只有精品视频| 亚洲视频欧美在线| 欧美一级视频| 免费视频最近日韩| 国产精品扒开腿做爽爽爽视频| 国产精品五区|