<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于嵌入式系統(tǒng)設(shè)計(jì)中查找內(nèi)存丟失的策略方案

          基于嵌入式系統(tǒng)設(shè)計(jì)中查找內(nèi)存丟失的策略方案

          作者: 時(shí)間:2012-03-13 來源:網(wǎng)絡(luò) 收藏

          分配位置

          有時(shí),位置信息比類型信息更為有效。幸而我們能夠靈活地使用宏定義,從而無須更換標(biāo)記即可選擇這些信息。

            ==========================

            #define mMalloc(size_t size)

            mMallocLineNo(size, __LINE__,

            __FILE__)

            =========================

          mMallocLineNo()函數(shù)是程序清單1中函數(shù)mMalloc()的變異。現(xiàn)在我們期望像程序清單3那樣存儲(chǔ)行號(hào)和文件名信息,為保持額外信息,結(jié)構(gòu)BlockEntry將具有如下形式:

            =========================

            typedef struct

            {

            void * addr;

            size_t size;

            int line;

            char * file;

            } BlockEntry;

            ==========================

          通過為每個(gè)塊存儲(chǔ)行號(hào)和文件名,就能精確地定位任何分配的塊??梢詾樗刑囟ㄩL度的表項(xiàng)一個(gè)輸出行號(hào)和文件名為mDisplayLocatiON()的函數(shù),這樣就能輕易地識(shí)別出長度可疑的塊的來源。

          再次回到表1,可能我們會(huì)擔(dān)心長度為44的內(nèi)存塊。為了更多地了解這些內(nèi)存的來源,可以在函數(shù)main()的末尾添加如下代碼:

            ========================

            mDisplayLocation(44);

            =======================

            這能將行44輸出50遍。

            =======================

            line = 162, file = listing2.c

            =======================

          這清晰地表明內(nèi)存塊在函數(shù)growForever()中分配。

          可變的長度

          某些內(nèi)存分配的長度可以發(fā)生急劇變化,例如:

            ==========================

            char *p = malloc(strlen(nAME)+1);

            ==========================

          是分配一塊足以存儲(chǔ)字符串名和字符串截止符的內(nèi)存的通用方法。在中,不會(huì)經(jīng)常對(duì)字符串和文件進(jìn)行操作;數(shù)據(jù)結(jié)構(gòu)的分配則不是這樣,例如:

            ==========================

            Motor *m = malloc(sizeof(Motor));

            ==========================

          如果假定Motor為存儲(chǔ)結(jié)構(gòu),那么上述分配將總是得到相同長度的內(nèi)存塊,在上面描述的函數(shù)中,將在輸出中更簡便地識(shí)別出這些內(nèi)存塊。

          在分配可變長度內(nèi)存塊時(shí),可以行號(hào)和文件名的組合為核心計(jì)算內(nèi)存分配的計(jì)數(shù)。示例中,我們存儲(chǔ)了行號(hào)和文件名,但打印的總數(shù)則取決于長度。通過行號(hào)和文件名的聚合分配將有助于在相同的位置將所有的分配組合起來,而不管分配的長度如何。某些情況下,即便可變的長度不成問題,這樣的分析仍然能帶給我們更多的啟發(fā)。

          內(nèi)存表

          任何含有內(nèi)存的代碼都將導(dǎo)致這里給出的內(nèi)存表不斷增大,而且并非所有的都能像growForever()示例那樣清晰無誤地進(jìn)行識(shí)別。即便采用其它技術(shù)進(jìn)行檢測和消除,這些輸出表仍將有助于確定丟失是否已被消除。

          這里給出的循環(huán)并不處理可變的輸入數(shù)據(jù)。在實(shí)際項(xiàng)目中,通常插入一些調(diào)用(如仿真鍵盤敲擊序列的調(diào)用)以模擬輸入。在實(shí)際中,還必須創(chuàng)建一些適當(dāng)?shù)妮斎?。除非自己希望改變代碼,否則完全無須訪問導(dǎo)致內(nèi)存丟失的代碼段。因此,這里的示例或許向大家提供了一個(gè)良好的開端,但任何內(nèi)存丟失仍然需要進(jìn)行一些檢測。

          linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

          上一頁 1 2 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();