chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Windows CE中的內(nèi)存泄漏問(wèn)題

嵌入式應(yīng)用開(kāi)發(fā) ? 來(lái)源:嵌入式應(yīng)用開(kāi)發(fā) ? 作者:嵌入式應(yīng)用開(kāi)發(fā) ? 2022-08-15 09:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

很多實(shí)時(shí)嵌入式設(shè)備是長(zhǎng)時(shí)間不間斷運(yùn)行的,即使是少許的內(nèi)存泄漏,也會(huì)積少成多,對(duì)嵌入式系統(tǒng)帶來(lái)災(zāi)難性的影響。這幾天,我在嵌入式軟件項(xiàng)目中就飽嘗到這個(gè)痛苦,讓我明白到嵌入式實(shí)時(shí)系統(tǒng)的應(yīng)用軟件也會(huì)有許多內(nèi)存問(wèn)題,從而導(dǎo)致嵌入式系統(tǒng)的崩潰。例如非法的內(nèi)存訪問(wèn)、各種死鎖以及諸如堆棧溢出、數(shù)組越界和內(nèi)存泄漏等

Windows CE作為最流行的一種嵌入式操作系統(tǒng),現(xiàn)正廣泛被應(yīng)用。我所負(fù)責(zé)的嵌入式應(yīng)用程序也是在Windows CE平臺(tái)上開(kāi)發(fā)的。在進(jìn)入測(cè)試階段中,我發(fā)現(xiàn)有一個(gè)程序模塊系統(tǒng)內(nèi)存和CPU資源消耗急劇增加,持續(xù)增長(zhǎng)到出現(xiàn)OutOfMemoryError為止,然后自動(dòng)重啟。這個(gè)問(wèn)題折騰到我生不如死,痛苦不堪?;宋液脦讉€(gè)通宵達(dá)旦的加班后,經(jīng)過(guò)分析終于確認(rèn)Windows CE內(nèi)存泄漏是造成這次Windows CE系統(tǒng)崩潰的主要原因。這里與大家分享我在開(kāi)發(fā)過(guò)程中遇到的內(nèi)存泄漏的檢測(cè)和處理解決過(guò)程。

一.Windows CE如何進(jìn)行內(nèi)存分配?

為了判斷是否有內(nèi)存泄露,我們首先需要了解Windows CE是如何管理內(nèi)存的。許多嵌入式程序員都有一個(gè)共識(shí),就是如果評(píng)選在Windows CE 程序中遇到最多的問(wèn)題,那其中一個(gè)問(wèn)題一定有內(nèi)存問(wèn)題。

(1)什么是Windows CE內(nèi)存管理

一般來(lái)說(shuō),運(yùn)行Windows CE的嵌入式設(shè)備出于緊湊型的考慮內(nèi)存都不大,以至于有時(shí)候有些程序員會(huì)為了節(jié)省內(nèi)存開(kāi)支而犧牲程序的某些性能。但盡管WinCE系統(tǒng)的內(nèi)存很小,用來(lái)管理內(nèi)存的函數(shù)卻十分完善。Windows CE實(shí)現(xiàn)了Windows XP中幾乎全部的Win32內(nèi)存管理API。例如,Windows CE支持虛擬內(nèi)存分配,本地和分離的堆管理,甚至還有內(nèi)存映射文件。像Windows XP一樣,Windows CE支持帶有應(yīng)用程序間內(nèi)存保護(hù)功能的32位地址空間,這一點(diǎn)對(duì)于多程序和多線程運(yùn)行時(shí)是非常重要的功能。但是Windows CE畢竟是被設(shè)計(jì)來(lái)應(yīng)用于實(shí)時(shí)場(chǎng)合的,所以它底層的內(nèi)存結(jié)構(gòu)又不同于Windows XP。

Windows CE內(nèi)核可以在Flash上直接運(yùn)行,也可以加載到內(nèi)存中運(yùn)行。Flash的運(yùn)行方式,是把內(nèi)核的可執(zhí)行映像燒寫到Flash上,系統(tǒng)啟動(dòng)時(shí)從Flash的某個(gè)地址開(kāi)始執(zhí)行。在這種情況下,Windows CE系統(tǒng)就像直接讀硬盤,存儲(chǔ)在Flash上的程序能夠以現(xiàn)場(chǎng)執(zhí)行的方式運(yùn)行。這種能力對(duì)小型系統(tǒng)來(lái)說(shuō)使之在具有巨大的優(yōu)勢(shì),這樣這能快速啟動(dòng)一個(gè)應(yīng)用程序,因此這種方法被很多嵌入式系統(tǒng)所采用。另一種是內(nèi)核加載方式,是把內(nèi)核的壓縮文件存放在Flash上,系統(tǒng)啟動(dòng)時(shí)讀取壓縮文件在內(nèi)存里解壓,然后開(kāi)始執(zhí)行。

(2)虛擬內(nèi)存和函數(shù)應(yīng)用

和大多數(shù)現(xiàn)代操作系統(tǒng)一樣,Windows CE實(shí)現(xiàn)按需調(diào)頁(yè)的虛擬內(nèi)存機(jī)制。由于Windows CE系統(tǒng)使用了虛擬內(nèi)存,這就給應(yīng)用程序造成了一個(gè)假象,以為計(jì)算機(jī)安裝的內(nèi)存遠(yuǎn)遠(yuǎn)超過(guò)自己所需要的數(shù)量。Windows CE是32位的操作系統(tǒng),因此支持4GB的虛擬地址空間。Windows把這些地址空間分給進(jìn)程和系統(tǒng)使用,每個(gè)部分可以獲得2GB的虛擬內(nèi)存。

虛擬內(nèi)存是內(nèi)存類型中最基礎(chǔ)的。Windows CE 實(shí)現(xiàn)了系統(tǒng)的虛擬內(nèi)存管理,在一個(gè)虛擬內(nèi)存系統(tǒng)中,應(yīng)用程序主要處理這個(gè)虛擬的地址空間,并不涉及到由硬件管理的物理內(nèi)存。系統(tǒng)調(diào)用虛擬內(nèi)存API來(lái)為其它類型內(nèi)存分配內(nèi)存,包括堆和棧。Windows CE虛擬內(nèi)存頁(yè)可以處在三種狀態(tài):自由(free),保留(reserved),或被提交(committed)。

簡(jiǎn)單說(shuō),就是當(dāng)一個(gè)應(yīng)用程序要查詢系統(tǒng)的內(nèi)存時(shí),可使用虛擬內(nèi)存API,包括VirtualAlloc,VirtualFree和VirtualReSize函數(shù),這些函數(shù)可以直接操作虛擬內(nèi)存空間的虛擬內(nèi)存頁(yè)面。例如,頁(yè)面可以保留,提交給物理內(nèi)存,或使用這些函數(shù)釋放。Windows CE實(shí)現(xiàn)了Win32的GetSystemInfo和GlobalMemoryStatus函數(shù)。另一個(gè)檢測(cè)系統(tǒng)狀態(tài)的函數(shù)是:void GlobalMemoryStatus(LPMEMORYSTATUS lpmst),通過(guò)GlobalMemoryStatus返回的信息可以驗(yàn)證Windows CE內(nèi)存結(jié)構(gòu)。

(3)釋放虛擬內(nèi)存

不同于Windows XP,Windows CE只支持在堆中分配固定(fixed)的塊。這簡(jiǎn)化了內(nèi)存塊在堆中的處理,但是這使得堆在分配和釋放一段時(shí)間后會(huì)產(chǎn)生碎片。當(dāng)堆里已經(jīng)清空的時(shí)候,仍然會(huì)占用大量的虛擬內(nèi)存頁(yè),因?yàn)橄到y(tǒng)不能在堆中內(nèi)存頁(yè)沒(méi)有完全釋放的時(shí)候回收這些頁(yè)。這時(shí),一般情況下是可以通過(guò)調(diào)用VirtualFree來(lái)取消提交,或釋放虛擬內(nèi)存。從物理RAM頁(yè)中取消提交或者取消映射,但是保持頁(yè)被保留的狀態(tài),當(dāng)在區(qū)域中的所有的頁(yè)通過(guò)VirtualFree被釋放時(shí),也應(yīng)該處在同樣的情況下。更確切地說(shuō),區(qū)域中的全部頁(yè)要被釋放,那這些頁(yè)要么都是被提交的頁(yè),要么都是被保留的頁(yè)。如果有些頁(yè)被提交,有些頁(yè)被保留,那么VirtualFree函數(shù)調(diào)用就會(huì)失敗。

實(shí)際上,Windows CE會(huì)監(jiān)視系統(tǒng)自由的內(nèi)存,并對(duì)越來(lái)越少的內(nèi)存作出響應(yīng)。當(dāng)很少內(nèi)存可用時(shí),Windows CE首先發(fā)送WM_HIBERNATE消息,接下來(lái)會(huì)限制可能的內(nèi)存分配。當(dāng)應(yīng)用程序被發(fā)送了一個(gè)WM_HIBERNATE消息后,系統(tǒng)將檢測(cè)內(nèi)存級(jí)別,確認(rèn)是否可用內(nèi)存在限度之上,如果可用內(nèi)存不足,WM_HIBERNATE消息將被發(fā)送給下一個(gè)程序,這會(huì)持續(xù)到所有程序被發(fā)送了WM_HIBERNATE消息。

二. 什么是內(nèi)存泄露

Win32編程中常見(jiàn)內(nèi)存錯(cuò)誤:①內(nèi)存分配錯(cuò)誤;②使用未初始化的內(nèi)存;③內(nèi)存泄露;④使用已經(jīng)釋放的內(nèi)存資源。

poYBAGL5pPWACkyiAADQEXbnnQk566.png

(1)什么是內(nèi)存泄漏

內(nèi)存泄漏是指程序在運(yùn)行過(guò)程中申請(qǐng)的內(nèi)存,在程序結(jié)束時(shí)沒(méi)有被釋放。我們常說(shuō)的內(nèi)存泄漏是指堆內(nèi)存的泄漏,堆內(nèi)存是指程序從堆中分配的。一般來(lái)說(shuō),應(yīng)用程序是使用從堆中分配到一塊內(nèi)存,使用完后程序必須負(fù)責(zé)相應(yīng)的釋放該內(nèi)存塊。否則,這塊內(nèi)存就不能被再次使用,我們就說(shuō)這塊內(nèi)存泄漏了。

一般來(lái)說(shuō),在所有時(shí)刻Windows CE內(nèi)存管理器都知道進(jìn)程所擁有的物理內(nèi)存和虛擬內(nèi)存。然而,如果進(jìn)程分配內(nèi)存時(shí)但由于Bug而無(wú)法釋放內(nèi)存(內(nèi)存泄漏),內(nèi)存管理器就可能無(wú)法了解這些已分配的內(nèi)存,也無(wú)法重新訪問(wèn)這些內(nèi)存,而必須等到進(jìn)程退出時(shí)回收內(nèi)存。但需要特別注意的是,同樣的程序在Window XP平臺(tái)上可能沒(méi)有什么問(wèn)題,但在缺乏內(nèi)存的Windows CE平臺(tái),經(jīng)過(guò)長(zhǎng)時(shí)間運(yùn)行該程序可能會(huì)內(nèi)存耗盡而導(dǎo)致系統(tǒng)重啟,這是我在經(jīng)過(guò)幾個(gè)生不如死的通宵達(dá)旦測(cè)試后得到的寶貴經(jīng)驗(yàn)和教訓(xùn)。

因此,內(nèi)存泄漏引發(fā)的性能失常完全不同于程序錯(cuò)誤,這些問(wèn)題很難通過(guò)調(diào)試器對(duì)代碼進(jìn)行單步調(diào)試加以解決。對(duì)于將會(huì)在某時(shí)刻退出的桌面應(yīng)用程序,較小的內(nèi)存泄漏是可以承受的,因?yàn)橥顺鲞M(jìn)程將把占用的所有內(nèi)存返還給操作系統(tǒng)。但對(duì)于長(zhǎng)時(shí)間運(yùn)行的嵌入式系統(tǒng),則通常需要確保絕對(duì)沒(méi)有內(nèi)存泄漏。

(2)常見(jiàn)的內(nèi)存泄漏原因

常見(jiàn)的內(nèi)存泄漏有這幾種原因:①Windows CE內(nèi)存碎片。②在局部堆申請(qǐng)的堆只增加不會(huì)馬上減少,直到程序退出。③程序運(yùn)行時(shí)分配物理內(nèi)存,當(dāng)程序使用完后,這些物理內(nèi)存仍然被占用,直到系統(tǒng)內(nèi)存不足時(shí)分頁(yè)內(nèi)存交換到分頁(yè)文件中,然后才釋放掉其占用的物理內(nèi)存。④Windows CE內(nèi)存管理的缺陷。

總而言之,內(nèi)存泄漏產(chǎn)生的主要原因是保留了卻不再使用的內(nèi)存空間。Windows CE雖然有自動(dòng)管理內(nèi)存的功能,但內(nèi)存泄漏也是不容忽視,它往往是破壞嵌入式系統(tǒng)穩(wěn)定性的重要因素。

三. 如何檢測(cè)和處理內(nèi)存泄漏?

如何查找引起內(nèi)存泄漏的原因,一般有兩個(gè)步驟:第一是安排有經(jīng)驗(yàn)的編程人員對(duì)代碼進(jìn)行走查和分析,找出內(nèi)存泄漏發(fā)生的位置。第二是使用專門的內(nèi)存泄漏測(cè)試工具進(jìn)行測(cè)試。

(1)代碼走讀檢測(cè)內(nèi)存泄漏

通常在懷疑發(fā)生內(nèi)存泄漏之后,第一步是要弄清楚泄漏了什么數(shù)據(jù)和引起了什么泄漏。一般說(shuō)來(lái),一個(gè)正常的系統(tǒng)在其運(yùn)行穩(wěn)定后其內(nèi)存的占用量是基本穩(wěn)定的,不應(yīng)該是無(wú)限制的增長(zhǎng)的。根據(jù)這樣的基本假設(shè),我們持續(xù)地觀察系統(tǒng)運(yùn)行時(shí)使用的內(nèi)存的大小,如果內(nèi)存的大小持續(xù)地增長(zhǎng),則說(shuō)明系統(tǒng)存在內(nèi)存泄漏。

內(nèi)存泄漏可通過(guò)代碼走讀來(lái)發(fā)現(xiàn)和定位,也可以用專用的工具來(lái)測(cè)試和定位。實(shí)際上,對(duì)于內(nèi)存泄漏,代碼檢查有時(shí)能比采用任何技術(shù)解決方案更快地找到問(wèn)題所在。預(yù)防內(nèi)存泄漏的唯一方法就是要求程序員在程序結(jié)束時(shí),必須將每個(gè)申請(qǐng)的內(nèi)存都釋放。

(2)使用工具檢測(cè)內(nèi)存泄漏

一旦知道確實(shí)發(fā)生了內(nèi)存泄漏,就需要更專業(yè)的工具來(lái)查明為什么會(huì)發(fā)生泄漏。在這個(gè)時(shí)候,我們通常需要使用一些開(kāi)銷較低的工具來(lái)監(jiān)控和查找內(nèi)存泄漏。查找內(nèi)存泄漏的工具很多,最常用的釋放工具就是dmalloc和mpatrol,這些工具提供了記錄并檢查所有內(nèi)存分配的調(diào)試版堆棧,從而有利于分析內(nèi)存泄漏和懸掛指針。

檢測(cè)內(nèi)存泄漏的關(guān)鍵是要能截獲住對(duì)分配內(nèi)存和釋放內(nèi)存的函數(shù)的調(diào)用,當(dāng)截獲住這兩個(gè)函數(shù),我們就能跟蹤每一塊內(nèi)存的生命周期。比如,每當(dāng)成功的分配一塊內(nèi)存后,就把它的指針加入一個(gè)全局的list中;每當(dāng)釋放一塊內(nèi)存,再把它的指針從list中刪除。這樣,當(dāng)程序結(jié)束的時(shí)候,list中剩余的指針就是指向那些沒(méi)有被釋放的內(nèi)存。哪么,最簡(jiǎn)單的內(nèi)存泄漏檢測(cè)方式就是截獲住這些指針。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5186

    文章

    20146

    瀏覽量

    328814
  • WINDOWS
    +關(guān)注

    關(guān)注

    4

    文章

    3694

    瀏覽量

    93227
  • 內(nèi)存泄漏
    +關(guān)注

    關(guān)注

    0

    文章

    40

    瀏覽量

    9491
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Windows CEWindows 2000/XP有什么區(qū)別?

    Windows系統(tǒng)。它使用平面內(nèi)存模式尋址,可以同時(shí)運(yùn)行多個(gè)程序并支持一個(gè)程序的多個(gè)線程,并且非常精煉,只有很小的內(nèi)存要求。
    發(fā)表于 10-15 08:10

    Windows CE板卡支持包介紹

    Windows CE板卡支持包用于netX的Windows CE 鏡像帶有一個(gè)周期為120天的免費(fèi)測(cè)試版。板卡支持包需要通過(guò)專用的驅(qū)動(dòng)創(chuàng)建自己的鏡像。其中包括
    發(fā)表于 04-11 08:50 ?27次下載

    基于Windows CE嵌入式系統(tǒng)的智能小區(qū)廣告機(jī)的設(shè)計(jì)

    Windows CE 是微軟公司專門為嵌入式市場(chǎng)設(shè)計(jì),為快速建立下一代小內(nèi)存占用的設(shè)備提供的一個(gè)健壯的實(shí)時(shí)操作系統(tǒng)。Windows CE
    發(fā)表于 08-18 10:15 ?19次下載

    ARM嵌入式WINDOWS CE實(shí)踐教程

    ARM嵌入式WINDOWS CE實(shí)踐教程 安裝WINDOWS CE 4.2本節(jié)講述如何安裝Windows
    發(fā)表于 03-01 15:45 ?81次下載

    Windows CE .NET 常見(jiàn)問(wèn)題與解答

    Windows CE .NET 常見(jiàn)問(wèn)題與解答 1. Microsoft Windows ® CE .NET®是什么?Microsoft
    發(fā)表于 07-07 10:09 ?1674次閱讀
    <b class='flag-5'>Windows</b> <b class='flag-5'>CE</b> .NET 常見(jiàn)問(wèn)題與解答

    Windows CE簡(jiǎn)介、特點(diǎn)及應(yīng)用

    Windows CE簡(jiǎn)介、特點(diǎn)及應(yīng)用 一、Windows CE簡(jiǎn)介  
    發(fā)表于 01-11 08:43 ?4806次閱讀

    Windows CE詳解

    從純粹軟件技術(shù)的角度看 Windows CE ,則可以說(shuō)Windows CE就是嵌入式的Windows,雖然
    發(fā)表于 06-09 15:51 ?67次下載

    Windows CE 進(jìn)程、線程和內(nèi)存管理三

    三、內(nèi)存管理 同其它Windows操作系統(tǒng)一樣,Windows CE.NET也支持32位虛擬內(nèi)存機(jī)制、按需分配
    發(fā)表于 11-08 10:30 ?0次下載
    <b class='flag-5'>Windows</b> <b class='flag-5'>CE</b> 進(jìn)程、線程和<b class='flag-5'>內(nèi)存</b>管理三

    內(nèi)存泄漏的特點(diǎn)和類型

    在計(jì)算機(jī)科學(xué),內(nèi)存泄漏(memory leak)指由于疏忽或錯(cuò)誤使程序未能釋放而造成不能再使用的內(nèi)存的情況。內(nèi)存
    的頭像 發(fā)表于 06-20 10:58 ?3264次閱讀

    什么是內(nèi)存泄漏?內(nèi)存泄漏有哪些現(xiàn)象

    內(nèi)存泄漏幾乎是很難避免的,不管是老手還是新手,都存在這個(gè)問(wèn)題,甚至 Windows 與 Linux 這類系統(tǒng)軟件也或多或少存在著內(nèi)存泄漏。
    的頭像 發(fā)表于 09-05 17:24 ?1.1w次閱讀

    怎么解決C語(yǔ)言中的內(nèi)存泄漏問(wèn)題呢?

    只有在堆內(nèi)存里面才會(huì)發(fā)生內(nèi)存泄漏的問(wèn)題,在棧內(nèi)存不會(huì)發(fā)生內(nèi)存
    發(fā)表于 06-11 17:31 ?788次閱讀
    怎么解決C語(yǔ)言中的<b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>問(wèn)題呢?

    什么是內(nèi)存泄漏?如何避免JavaScript內(nèi)存泄漏

    JavaScript 代碼中常見(jiàn)的內(nèi)存泄漏的常見(jiàn)來(lái)源: 研究內(nèi)存泄漏問(wèn)題就相當(dāng)于尋找符合垃圾回收機(jī)制的編程方式,有效避免對(duì)象引用的問(wèn)題。
    發(fā)表于 10-27 11:30 ?1297次閱讀
    什么是<b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>?如何避免JavaScript<b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>

    內(nèi)存泄漏會(huì)產(chǎn)生哪些后果

    ,只釋放了p1,沒(méi)有釋放p2,產(chǎn)生了內(nèi)存泄漏。 內(nèi)存泄漏會(huì)產(chǎn)生哪些后果? 隨著程序運(yùn)行時(shí)間越來(lái)越久,內(nèi)存有分配沒(méi)有釋放,會(huì)使得進(jìn)程堆
    的頭像 發(fā)表于 11-10 15:06 ?1399次閱讀
    <b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>會(huì)產(chǎn)生哪些后果

    線程內(nèi)存泄漏問(wèn)題的定位

    記錄一個(gè)關(guān)于線程內(nèi)存泄漏問(wèn)題的定位過(guò)程,以及過(guò)程的收獲。 1. 初步定位 是否存在內(nèi)存泄漏:想到內(nèi)存
    的頭像 發(fā)表于 11-13 11:38 ?1181次閱讀
    線程<b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>問(wèn)題的定位

    C語(yǔ)言內(nèi)存泄漏問(wèn)題原理

    內(nèi)存泄漏問(wèn)題只有在使用堆內(nèi)存的時(shí)候才會(huì)出現(xiàn),棧內(nèi)存不存在內(nèi)存泄漏問(wèn)題,因?yàn)闂?/div>
    發(fā)表于 03-19 11:38 ?1068次閱讀
    C語(yǔ)言<b class='flag-5'>內(nèi)存</b><b class='flag-5'>泄漏</b>問(wèn)題原理