www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]基于嵌入式系統(tǒng)設(shè)計中查找內(nèi)存丟失的策略方案

在嵌入式系統(tǒng)設(shè)計過程中,要利用數(shù)組保存內(nèi)存分配的每一個塊記錄,在內(nèi)存塊釋放的同時,也將該記錄從數(shù)組中刪除。在主循環(huán)的每次迭代之后,分配的內(nèi)存塊的總數(shù)目將打印出來。理想情況下,要按類型對這些內(nèi)存塊排序,但指向malloc()和free()的調(diào)用則不包含任何類型信息。內(nèi)存分配的大小是最好的標(biāo)識,因此成為設(shè)計工程師需要記錄的信息。此外,還需要存儲分配的內(nèi)存塊地址信息,這樣,當(dāng)調(diào)用釋放函數(shù)時,就可以方便地定位或刪除塊記錄。

在添加和刪除塊記錄時,還需要跟蹤每種大小的內(nèi)存塊數(shù)目,程序的列表1給出了實現(xiàn)上述功能的代碼。

隨著內(nèi)存塊的分配和釋放,數(shù)組:
  =======================

  typedef struct

  {

  void * address;

  size_t size;

  } BlockEntry;

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

跟蹤當(dāng)前存在的所有內(nèi)存塊。另一數(shù)組則跟蹤當(dāng)前存在的每種大小的內(nèi)存塊總數(shù):

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

  typedef struct

  {

  int count;

  size_t size;

  } Counter;

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

函數(shù)mDisplayTable()允許我們在每次主循環(huán)結(jié)束時輸出結(jié)果。如果printf()不可用,則可利用調(diào)試器中斷系統(tǒng)并檢驗數(shù)組的內(nèi)容。

上述代碼還必須使NUM_SIZES 和 NUM_BLOCKS足夠大,以處理系統(tǒng)中的大量內(nèi)存分配;但也不能太大,從而導(dǎo)致在系統(tǒng)運行之前就已耗盡所有的RAM。

輸出

快速地瀏覽代碼,可以注意到結(jié)構(gòu)類型Sensor的長度定義如下:

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

  typedef struct

  {

  int offset;

  int gain;

  char name[10];

  } Sensor;

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

假定int為32位數(shù)據(jù),那么Sensor的長度將為18(4+4+10),但在測試中,結(jié)果表明為20。編譯器可以在存儲結(jié)構(gòu)的數(shù)據(jù)成員之間自由地添加填充,以將對齊強(qiáng)制設(shè)定為一個字邊界。特殊情況下,每個字段開始于一個已存在的字邊界,那么為什么還需要填充呢?填充添加在存儲結(jié)構(gòu)的最末端,如果聲明了一個數(shù)組Sensor,那么該數(shù)組的所有成員(而不僅僅是第一個成員)將會進(jìn)行字對齊。根據(jù)處理器的不同,字對齊的速度將有所差異,有時這些編譯器將提供可根據(jù)速度選擇字對齊長度的切換開關(guān)。在任何情形下,最好不要根據(jù)源代碼的定義對存儲結(jié)構(gòu)的長度作任何假設(shè)。

下面考察當(dāng)使用這些函數(shù)時,將得到何種類型的輸出。程序清單2給出了一個顯示存儲動態(tài)內(nèi)存方式的示例。程序清單2將通常作為主外部循環(huán)的迭代了10次,并在每次迭代的末尾,調(diào)用函數(shù)mDisplay-Table()輸出分配的內(nèi)存塊情況。

許多內(nèi)存塊均在初始化階段進(jìn)行分配,但我們對這些內(nèi)存塊并不感興趣,因為這段代碼將不會重復(fù),因此不會產(chǎn)生內(nèi)存丟失。由于我們并不希望這些內(nèi)存分配導(dǎo)致分配表混亂,因此在啟動感興趣的迭代之前需要將該分配表清空。為了清空分配表,需要調(diào)用函數(shù)mClearTable()。

主循環(huán)調(diào)用的三個不同的函數(shù)

函數(shù)replacer():指示了一個用來分配內(nèi)存塊并且直到出現(xiàn)循環(huán)迭代才釋放的指針。如果檢驗主循環(huán)中的迭代,可以發(fā)現(xiàn)分配的內(nèi)存塊并未釋放。通過監(jiān)控總數(shù)為20的內(nèi)存塊,從表1可以看出,每次迭代之后的內(nèi)存塊總數(shù)都為1,因此沒有出現(xiàn)內(nèi)存丟失。

函數(shù)growAndShrink():管理長度為24個結(jié)構(gòu)體的鏈表,該鏈表的長度將隨時間發(fā)生變化,但我們并不希望鏈表無限增長。通過檢驗總數(shù)為24的內(nèi)存塊,我們可以發(fā)現(xiàn),雖然任意時間內(nèi)存塊的數(shù)目都可能發(fā)生變化,但決不會超過25個。

函數(shù)growForever():處理內(nèi)存塊長度為44的情形。這里我們可以非常清晰地看到,分配的內(nèi)存塊數(shù)目在持續(xù)增長。當(dāng)首次觀察該表時,可能無法找到表的源頭。我們首先只能快速而粗略對mMalloc()上的條件斷點進(jìn)行檢驗,該斷點只有當(dāng)長度參數(shù)達(dá)到44時才觸發(fā)。當(dāng)?shù)竭_(dá)該斷點時,可以檢驗堆棧,以確定進(jìn)行內(nèi)存分配的地方。工程師完全能夠多次執(zhí)行這樣的操作,因為這種長度的內(nèi)存塊可在多處進(jìn)行分配。

嚴(yán)格地說,在函數(shù)growForever()中分配的內(nèi)存不是丟失,因為所有分配的內(nèi)存塊均帶有引用,因此理論上可以在后來釋放。如果特定應(yīng)用這樣做,那么結(jié)果就非常明顯。

長度是關(guān)鍵因素

當(dāng)不同類型的對象共享相同長度的內(nèi)存時,上述技術(shù)就不那么有效了。實際中碰到這樣的情形并不多,但即便可能引發(fā)問題,仍然還有很多別的選擇。

更為先進(jìn)的方法則是為每個記錄存儲類型信息。這并不困難,但我卻不愿采用這種方法,因為該方法要求為函數(shù)mMalloc()的標(biāo)記添加一些新東西。我們可以定義一個列出所有可能分配的類型的枚舉類型。在每次調(diào)用函數(shù)mMalloc()時,將傳遞一個附加的參數(shù),并且該參數(shù)為枚舉類型中的一個元素。如果在表中該參數(shù)連同地址一起被存儲,那么總能識別出這類對象。

這也使得我們可以將分配長度不同,但類型相關(guān)(如可變長度的字符數(shù)組)的內(nèi)存塊鏈接起來。

C++通過使我們重載或刪除按類基(per-class basis)而使得這種方法更加簡便易行。盡管這是一種有效的方法,但這里我仍然不會采用這種方法,因為我更傾向采用適合C語言環(huán)境的技術(shù)。[!--empirenews.page--]

分配位置

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

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

  #define mMalloc(size_t size)

  mMallocLineNo(size, __LINE__,

  __FILE__)

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

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

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

  typedef struct

  {

  void * addr;

  size_t size;

  int line;

  char * file;

  } BlockEntry;

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

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

再次回到表1,可能我們會擔(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);

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

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

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

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

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

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

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

內(nèi)存表

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

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

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉