• <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 - 9,  comments - 16,  trackbacks - 0
            ??????? 題目描述很簡(jiǎn)單:內(nèi)存泄露了,現(xiàn)象是看到該程序的內(nèi)存占用率不斷增長(zhǎng),作為一個(gè)程序員你怎么解決這個(gè)問(wèn)題?

            ??????? 我答的不好,回來(lái)之后又好好的想了想,其實(shí)回答這個(gè)問(wèn)題應(yīng)該從不同的方面來(lái)考慮

            ??????? 首先分析內(nèi)存泄露容易發(fā)生的情況,《OOP啟示錄》對(duì)這些情況都講得挺詳細(xì)的,在類的構(gòu)造函數(shù)與析構(gòu)函數(shù)中沒(méi)有匹配地調(diào)用 new/delete!沒(méi)有正確地清除嵌套的對(duì)象指針!在釋放對(duì)象數(shù)組時(shí),沒(méi)有使用delete [];指向由指向?qū)ο蟮闹羔槝?gòu)成的數(shù)組不等同于與對(duì)象數(shù)組。缺少拷貝構(gòu)造函數(shù),編譯器缺省添加的拷貝構(gòu)造函數(shù)不足,缺省的拷貝構(gòu)造函數(shù)采用位拷貝!......用我自己的想法描述就是,每次自己分配一塊內(nèi)存區(qū)域的時(shí)候,都要想到用完之后要將該內(nèi)存區(qū)釋放掉!當(dāng)然特殊的情形這句話不適用。
            ?????? 既然知道了內(nèi)存泄露事件的多發(fā)地帶,我們可以多在這些地方設(shè)置檢察機(jī)制,相對(duì)來(lái)說(shuō)就有一點(diǎn)針對(duì)性了!面試官說(shuō)這樣是一種解決辦法,可能10000個(gè)函數(shù),我們可以把錯(cuò)誤范圍縮小到200個(gè),然后你還有什么辦法繼續(xù)解決這個(gè)問(wèn)題?

            ??????我基本上是把我暫時(shí)能想到的都說(shuō)了,什么設(shè)置斷點(diǎn)調(diào)試啊,用IDE工具看地址變化。。。不過(guò)好像都不能達(dá)到面試官滿意度。。。
            ????? 他說(shuō)沒(méi)有這樣的IDE工具給你用,接著你怎么解決?
            ????? 唉。。。受打擊了,事實(shí)如此,我對(duì)這個(gè)不夠理解。。。

            ???? 之后上網(wǎng)想找找內(nèi)存泄露相關(guān)的資料,搜出來(lái)的文章大部分都是林銳高質(zhì)量C++編程里關(guān)于內(nèi)存的那篇,大感失望,怎么就沒(méi)有其他更好更深入的文章了呢???

            ???? 大家討論討論,我相信這個(gè)問(wèn)題挺具有代表性的,大家討論出個(gè)結(jié)果,都弄懂了豈不是更好?


            posted on 2006-05-13 02:42 季浩 閱讀(2180) 評(píng)論(10)  編輯 收藏 引用 所屬分類: 心得體會(huì)

            FeedBack:
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-13 09:57 | blueice
            如果可能的話,分段測(cè)試,使用排除定位的方式找到代碼段,但這樣付出的事件和精力是很客觀的!  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-13 10:57 | flyingxu
            沒(méi)有工具用的話,估計(jì)內(nèi)存泄漏是很難檢查出來(lái)的。有工具干嘛不用?  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-13 11:15 | 音樂(lè)蟲子
            非常同意樓上的,不給你米請(qǐng)問(wèn)你如何做飯?
            你得先在大自然等待一個(gè)水稻誕生,然后收集種子,再培育,再收集再培育,到了購(gòu)量了之后,還要去殼什么的,再去找木頭,磚頭搭一個(gè)爐,然后收集一點(diǎn)鐵來(lái)打一個(gè)鍋,最后跑50里到海邊打一通水回來(lái),然后開(kāi)始做飯!

            或者,你可以直接到飯店花錢買一碗飯回來(lái)就好了。

            你可以告訴面試的人,拋棄有內(nèi)存泄露的軟件,買別人的不泄露的,搞定!

              回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-13 21:59 | 蝦米
            我估計(jì)面視你的人是想問(wèn)你如何做好內(nèi)存管理,這確實(shí)不事件容易的事情,也需要對(duì)C++的理解更深入一層。

            我提一個(gè)方法,重載new/delete, 讓程序使用一段自己管理的內(nèi)存空間,這個(gè)內(nèi)存空間大小最好可以變化,但不能頻繁發(fā)生。在發(fā)生內(nèi)存泄漏時(shí)候,報(bào)告發(fā)生問(wèn)題的對(duì)象或者是過(guò)程……  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-14 16:56 | 季浩
            有的程序不能用調(diào)試的方法,找出錯(cuò)誤。。。
            IDE有時(shí)候?qū)τ械某绦虿恢С终{(diào)試,比如寫了一個(gè)Windows服務(wù)程序,怎么樣調(diào)試呢? 你能看到內(nèi)存不斷被吃掉,但是總得想辦法來(lái)解決。。。

            蝦米兄弟說(shuō)的方法,我另一個(gè)兄弟也說(shuō)過(guò),感覺(jué)想法挺好的
            重載new/delete, 讓程序使用一段自己管理的內(nèi)存空間,這個(gè)內(nèi)存空間大小最好可以變化,但不能頻繁發(fā)生。在發(fā)生內(nèi)存泄漏時(shí)候,報(bào)告發(fā)生問(wèn)題的對(duì)象或者是過(guò)程……  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-15 08:48 | 明明
            呵呵, 才發(fā)現(xiàn)這還有一家子的人呢. 俺也姓季. 呵呵. 常聯(lián)系   回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-15 10:30 | 空明流轉(zhuǎn)
            很明顯的,考官是要考驗(yàn)?zāi)阌袥](méi)有比較扎實(shí)的C++功底和Track的習(xí)慣。

            其實(shí)一般來(lái)說(shuō)程序稍微大一點(diǎn)都是重載了內(nèi)存分配函數(shù)然后使用自己訂制的內(nèi)存分配器監(jiān)察內(nèi)存分配情況。適當(dāng)?shù)臅r(shí)候Log就可以了。  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-16 19:46 | jinti
            查內(nèi)存泄露是需要時(shí)間的。最好的方法是養(yǎng)成代碼編寫習(xí)慣
            盡量使用智能指針。

            查內(nèi)存的工具有:valgrid, 很好用,可惜在windows下沒(méi)有.

            不過(guò)也有一些代碼上的技巧, 比如:重載class 的 new和delete操作。記錄之后再進(jìn)行一步一步的排查。  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教
            2006-05-27 20:31 | Corner
            @jinti
            我想在防范措施上以養(yǎng)成良好的編碼習(xí)慣

            在跟蹤技巧上可以寫一個(gè)跟蹤對(duì)象生存期的Track類,重點(diǎn)是在constructor/destructor和copy constructor里加入一些必要的紀(jì)錄驗(yàn)證操作或是log輸出操作。

            在語(yǔ)言的機(jī)制上可以重載全局new/delete,對(duì)于C code可以寫自己的malloc/realloc/free,同時(shí)為了保持代碼的整潔,可以適當(dāng)使用一點(diǎn)macro,比如:
            #define new mycode::new // mycode::是名稱空間
            這么做是為了盡可能少的改動(dòng)原有代碼。

            當(dāng)然更有力的技術(shù)是SmartPtr/ObjPool, 不過(guò)當(dāng)進(jìn)入多線程的世界,會(huì)使問(wèn)題更為復(fù)雜些,這時(shí)關(guān)鍵在于搞清楚你的對(duì)象的生存期大于所在的線程,還是小于它.值得注意的是SmartPtr/ObjPool技術(shù)會(huì)引入一個(gè)間接操作,得根據(jù)場(chǎng)合進(jìn)行取舍。  回復(fù)  更多評(píng)論
              
            # re: 前天一道我不能回答好的面試題:內(nèi)存泄露你怎么解決?希望大家不吝賜教[未登錄](méi)
            2007-02-03 19:56 | 季浩
            呵呵,我和你同名同姓耶,516790691,我的QQ號(hào),蠻想見(jiàn)你的  回復(fù)  更多評(píng)論
              
            Locations of visitors to this page
            <2007年2月>
            日一二三四五六282930311234567891011121314151617181920212223242526272812345678910

            常用鏈接

            留言簿(3)

            隨筆分類(8)

            隨筆檔案(9)

            fiends

            搜索

            •  

            積分與排名

            • 積分 - 16158
            • 排名 - 936

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久影院亚洲一区| 91久久精品国产91性色也| 色诱久久av| 亚洲精品第一综合99久久| 久久人人爽人人爽人人片av高请| 1000部精品久久久久久久久| 91精品婷婷国产综合久久| 久久精品中文字幕大胸| 日本久久久精品中文字幕| 香蕉99久久国产综合精品宅男自| 久久午夜无码鲁丝片| 久久久久亚洲精品天堂久久久久久| 2020久久精品亚洲热综合一本| 久久久精品人妻一区二区三区蜜桃 | 久久久国产乱子伦精品作者| 久久精品一区二区| 久久综合亚洲色HEZYO社区| 亚洲成色999久久网站| 77777亚洲午夜久久多人| 久久精品国产99久久久香蕉| 青青草原精品99久久精品66| 久久精品成人欧美大片| 97久久国产亚洲精品超碰热| 欧美国产成人久久精品| 国产高潮久久免费观看| 国内精品伊人久久久久| 亚洲欧美日韩中文久久| 欧美激情精品久久久久久| 久久国产精品-国产精品| 男女久久久国产一区二区三区| 久久国产精品免费一区| 99久久免费国产特黄| 久久久一本精品99久久精品88| 奇米影视7777久久精品人人爽| 国产激情久久久久影院| 大美女久久久久久j久久| 久久国产精品-久久精品| AAA级久久久精品无码片| 丁香五月网久久综合| 久久久久久a亚洲欧洲aⅴ| AV狠狠色丁香婷婷综合久久|