国产九九热视频-国产九九精品视频-国产精自产拍久久久久久蜜-国产精自产拍久久久久久-国产精在线-国产精亚洲视频


曙海教育集團(tuán)論壇3G手機(jī)技術(shù)專區(qū)Symbian開發(fā) → 如何使用新版HooKlogger查找內(nèi)存泄露


  共有8351人關(guān)注過本帖樹形打印

主題:如何使用新版HooKlogger查找內(nèi)存泄露

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個(gè)性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
如何使用新版HooKlogger查找內(nèi)存泄露  發(fā)帖心情 Post By:2010-12-3 13:54:40

我才學(xué)塞班1個(gè)多星期吧,對(duì)其理解還不是很透徹,不過現(xiàn)在已經(jīng)會(huì)使用HOOKLOGGER來找內(nèi)存泄露了,這個(gè)工具還是蠻準(zhǔn)的,由于官方最新版的安裝方法和老版本的稍微有些區(qū)別了,所以導(dǎo)致很多人都安裝失敗,我也是看了鬼人王大哥的帖子后才知道有這個(gè)軟件的,不過鬼人王大哥的帖子的安裝方法貌似已經(jīng)過時(shí)了,反正我安了后模擬器再也啟動(dòng)不了了,導(dǎo)致GHOST了1次,還好備份了。
首先建議大家設(shè)置好環(huán)境后一定要GHOST備份呀,要是模擬器啟動(dòng)不了了那就麻煩了,費(fèi)時(shí)費(fèi)力啊。

這個(gè)方法適用于第3版SDK,貌似新的HOOK工具不能用于低于2版FP3之前的版本,不保證該帖子的時(shí)效性,具體還得看hooklogger官網(wǎng)(我是直接學(xué)的3版,對(duì)2版一點(diǎn)也不懂)。
首先去官網(wǎng)下載安裝包(如果能從人王大哥那要來老版本的話,可以用他的方法來安裝,不過新版本不用設(shè)置環(huán)境變量,不用重啟如果沒記錯(cuò)的話,就1條命令搞定):
1. 開始-運(yùn)行 CMD,在控制臺(tái)下邊輸入:SetupHooks  S60_3rd_MR:com.nokia.s60

如上圖所示,因?yàn)槲乙呀?jīng)安裝好了,所以提示我有個(gè)目標(biāo)存在。
SetupHooks是命令,空格后是我3版的版本號(hào)吧,也就是在控制臺(tái)下輸入devices后可以看到的,也可能你們和我的不一樣,我們老師推薦弄MR的。
輸入完命令按完回車后,會(huì)有提示,提示很簡單看看就能知道成功與否。

2.好了,安完后就可以使用它方便快捷的來找內(nèi)存泄露了,先運(yùn)行l(wèi)og,再運(yùn)行模擬器哦,先說下我的環(huán)境:3版SDK,IDE安了VS2005和CARBIDE,不過主要用2005開發(fā)
打開hooklogger后標(biāo)題會(huì)顯示沒有和模擬器連接,如下圖:

接著我們啟動(dòng)模擬器吧(我估計(jì)是安裝某個(gè)環(huán)節(jié)出了點(diǎn)問題,反正一啟動(dòng)就提示leave了(出現(xiàn)時(shí)會(huì)自動(dòng)進(jìn)入debug模式,選continue就行),不過無視它吧,狂點(diǎn)運(yùn)行肯定可以啟動(dòng)模擬器)
啟動(dòng)成功后進(jìn)入我們的目標(biāo)工程,運(yùn)行一遍直到內(nèi)存泄露為止,接著模擬器界面出現(xiàn)提示說內(nèi)存泄露在內(nèi)存的某個(gè)位置,如下圖:

接著我們切換到log的界面吧,找到Threads(最后1個(gè))這個(gè)標(biāo)簽,把下拉條拉到最底部,我們能看到我們工程的這個(gè)線程,如下圖:

這個(gè)是我的工程名,一時(shí)心急,名字敲錯(cuò)了,嘿嘿,這個(gè)一般也是在線程的最底部的位置,接著右鍵單擊,選擇如圖:

接著log會(huì)自己跳轉(zhuǎn)到Heap標(biāo)簽下,里面顯示了內(nèi)存地址,如圖:

對(duì)比一下模擬器報(bào)錯(cuò)的地址很輕易就找到了位置,我們雙擊一下,自動(dòng)進(jìn)去一個(gè)窗口,里面顯示了1堆代碼,一般里面列出的第1個(gè)函數(shù)就是內(nèi)存泄露的位置,如圖(該點(diǎn)是從人王大哥那學(xué)到的):

接著我們雙擊進(jìn)入這個(gè)函數(shù),也會(huì)自動(dòng)蹦出1個(gè)對(duì)話框窗體,里面高亮部分就是我們出現(xiàn)泄露的地方,如圖:

接著我們就可以去代碼里找了,注意不一定出現(xiàn)泄露的地方就是在該句代碼附近,而只是表明,這個(gè)泄露跟這句代碼是有關(guān)系的,果然我這new了1個(gè)空間,很可能是我沒有釋放導(dǎo)致泄露的,那就去釋放的地方看看吧。

先解釋一下我這個(gè)有意的泄露吧,我這定義了1個(gè)局部指針,但不是在這個(gè)類里析構(gòu)把它放掉的,我定義了1個(gè)rpointerarray數(shù)組保存這些指針,而這些指針都是保存在我自定義的1個(gè)9宮格類里,所以自然我們要去我9宮格類的析構(gòu)里看看到底問題出在哪,如圖:

果然,我的數(shù)組只reset了沒有把new在堆上的數(shù)據(jù)給釋放,所以導(dǎo)致泄露了,只要把注掉的那句代碼替換reset就OK了。
接著我們重新build一下工程吧,這個(gè)時(shí)候可能會(huì)報(bào)錯(cuò),沒事,轉(zhuǎn)到log界面,這時(shí)它會(huì)碰出1個(gè)詢問框,大概就是左邊是個(gè)relloc按鈕右邊是個(gè)release按鈕,我選擇了左邊的按鈕,接著build一切OK。
END。
由于本人接觸計(jì)算機(jī)時(shí)間有限,這也是在技術(shù)論壇上的第1個(gè)帖子,我是今年7月才第1次接觸C語言的,現(xiàn)在塞班也才學(xué)1個(gè)多星期,肯定會(huì)有所紕漏,希望大家指正,在次再次感謝人王大哥的帖子,如果有人轉(zhuǎn)載希望表名出自devdiv

支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

如何使用新版HooKlogger查找內(nèi)存泄露








簽名
主站蜘蛛池模板: 山东省| 宽甸| 天全县| 双辽市| 新郑市| 井研县| 刚察县| 赤壁市| 车险| 光泽县| 牟定县| 壶关县| 永和县| 黔江区| 闽侯县| 博白县| 德阳市| 睢宁县| 黄龙县| 宜州市| 大化| 个旧市| 泰州市| 宁蒗| 岳阳市| 曲阳县| 建阳市| 宁安市| 遵义市| 定日县| 金溪县| 宣威市| 阿拉尔市| 临安市| 彭州市| 开鲁县| 奎屯市| 百色市| 汶上县| 海门市| 溧阳市|