青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-380  評論-37  文章-0  trackbacks-0

轉:http://www.cnblogs.com/minggoddess/archive/2010/12/15/1907179.html

動態鏈接庫中分配內存引起的

       本文主要是探討關于在動態鏈接庫分配的內存在主程序中釋放所產生的問題,該問題是我在剛做的PJP工程中所遇到的,由于剛碰到之時感動比較詭異(這也是學識不夠所致),所以將它寫下來,大家一起分享.

       問題來由:

由于該工程中要用到聲音,所以我的分工之一就是用DirectMusic和DirectSound來開發聲音播放的動態庫,以提供給該工程的兩個部分:仿真控制部分( 語音 )和三維部分( 場景聲音 )使用,兩個工程中的聲音都以單獨的線程播放,且兩個線程幾乎相同.,然而該動態庫在以前的運行中一直沒有出現過問題, 直到工程開發即將要結束階段的前一個星期,我碰才到了這個問題,首先是三維部分中聲音在第一次播放是沒有問題,在播放第二個聲音就出了問題(老是這樣),但是仿真控制部分還是沒有出現問題,我查不出錯誤,就用前一天的三維的版本來運行,重新生成后聲音播放沒有問題,初步以為是我同事當天寫的代碼有問題,可是第二天,同樣的問題又發生了,還是那樣,三維有問題,仿真部分沒問題,怎么回事呢?我將三維的聲音線程寫成和仿真部分一樣的,還是三維出問題,仿真沒問題.我不相信是動態庫中出問題,同一個動態庫,同樣的代碼,只是在兩個不同的程序里,為什么一個出問題,而另一個不出問題呢?

       出錯信息如下:

                  windows已在PowipD.exe中觸發一個斷點.
                  其原因可能是堆被損壞,這也說明PowipD.exe中或它所加載的任何DLL中有bug.
                  輸出窗口可能提供了更多診斷信息

       按下中斷后輸入窗口出現的信息如下:

               HEAP[PowipD.exe]:Invalid Address specified to RtlValidateHeap( 01CC0000, 03723758 )
               Windows已在PowipD.exe中觸發一個斷點.
               輸出窗口可能提供了更多診斷信息

       由于這些原因讓我迷惑不解,到底是為什么出現這種奇怪的事情呢?問題出在那里?

 

問題的解決:

簡單地說:DLL中分配的內存DLL要負責釋放!(一個模塊分配的內存要在同一個模塊中釋放!)

找到解決方法后我查看了三個工程的設置(三個工程皆用VS2005開發):

       三維:使用MDd(多線程調試DLL)運行期庫

       仿真控制:使用MTd(多線程調試)運行期庫

       聲音動態庫:使用MDd(多線程調試DLL)運行期庫

于是,我將三個工程皆改為:使用MDd(多線程調試DLL)運行期庫時,問題解決。

但是如果三個工程中有的不是用C/C++寫的,或者其中有工程的設置已經不便更改了,那又有什么辦法呢?

該問題主要是關于DLL與進程的地址空間的問題(下面是<<核心編程>>中的一段話):

單個地址空間是由一個可執行模塊和若干個DLL模塊組成,這些模塊中,有些可以鏈接到靜態版本的C/C++運行期庫, 有些可以鏈接到一個DLL版本的運行期庫,而有些模塊(如果不是用C/C++編寫的話)則根本不需要C/C++運行期庫,許多開發人員經常會犯一個常見的錯誤,因為他們忘記了若干個C/C++運行期庫可以存在于單個地址空間中.請看下面的代碼(下面代碼不是書上的):

DLL中如下:

       int *DllFunc()

{

       int *p = new int;

       return p;

}

 

EXE中如下:

void EXEFunc()

{

       int *p = DllFunc();

       if( p!= NULL )

              delete p;

}

 

如何看待這個問題呢?上面的代碼能夠正確運行嗎?DLL函數分配的內存是由EXE的函數釋放的嗎?答案是可能的.上面顯示的代碼并沒有提供足夠的信息.如果EXE和DLL都鏈接到DLL的C/C++運行期庫,那么上面的代碼將能夠很好地運行.但是,如果兩個模塊中的一個或者兩個鏈接到靜態C/C++運行期庫,那個對delete的操作就會失敗.

一個很方便的方法可以解決這個問題.當一個模塊提供一個用于分配內存塊的函數時,該模塊也必須提供相應的釋放內存的函數,將上面的代碼改成如下的樣子就不會出錯了:

 

DLL中如下:

       int *DllFunc()

{

       int *p = new int;

       return p;

}

 

void DLLDelete( int *p)

{

       if( p != NULL )

              delete p;

}

 

EXE中如下:

void EXEFunc()

{

       int *p = DllFunc();

       DLLDelete( p );

}

這樣的代碼才是正確的,當我將代碼改成如上類似后,再將三維的運行期庫改為原來一樣(使用MDd(多線程調試DLL)運行期庫),三維的聲音也正確無誤地播放出來了。當你在編寫一個模塊時,你時刻都得記著,別人的代碼不一定是用C/C++寫的,也有可能不能同時鏈接到DLL的C/C++運行期庫。malloc和free函數也有類似的問題。

當然在你在生成你的模塊時是可以選擇運行期庫的,VC 6.0配有6個運行期庫:其描述如下:

 

庫名

描述

LibC.lib

用于單線程應用程序的靜態應用程序的靜態鏈接庫      

LibCD.lib

用于單線程應用程序的靜態鏈接庫的調試版

LibCMt.lib

用于多線程應用程序的靜態鏈接庫的發行版

LibCMtD.lib

用于多線程應用程序的靜態鏈接庫的調試版

MSVCRt.lib

用于動態鏈接MSVCRt.dll庫的發行版的輸入庫

MSVCRtD.lib

用于動態鏈接MSVCRtD.dll的調試版的輸入庫。該庫同時支持單線程應用程序和多線程應用程序

 

而VS2005中只配了4個C/C++運行期庫,就是上表中的后面4個。

建議各位在軟件開發時同一軟件的不同模塊最好使用一致的運行庫,否則還可能出現鏈接問題。

posted on 2012-06-02 17:52 小王 閱讀(1800) 評論(1)  編輯 收藏 引用 所屬分類: VC

評論:
# re: 動態鏈接庫分配的內存在主程序中釋放所產生的問題 2012-06-03 02:03 | egmkang
程序的接口有問題.
誰申請的,誰釋放;誰提供申請的接口,誰也提供釋放的接口  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美粗暴jizz性欧美20| 99一区二区| 亚洲茄子视频| 韩国av一区二区三区四区| 老司机午夜免费精品视频| 日韩视频精品| 欧美在线观看天堂一区二区三区| 国内精品伊人久久久久av影院 | a91a精品视频在线观看| 欧美日本成人| 久久九九久精品国产免费直播| 亚洲电影av| 久久久精彩视频| 欧美91大片| 久久久久高清| 亚洲欧美日韩国产一区| 亚洲精品你懂的| 欧美成人免费网站| 久久婷婷av| 香蕉亚洲视频| 亚洲午夜激情在线| 日韩午夜三级在线| 亚洲国产精品一区二区第四页av | 国产精品久久久久aaaa九色| 免费成人高清在线视频| 久久激情婷婷| 欧美伊久线香蕉线新在线| 一本色道久久综合亚洲精品按摩| 亚洲免费观看在线视频| 在线观看欧美视频| 伊人成人开心激情综合网| 国产一区二区三区四区hd| 国产精品―色哟哟| 国产精品久久久久av| 欧美三级在线播放| 欧美区国产区| 欧美视频在线观看视频极品| 欧美精品久久一区| 欧美日韩国产成人在线91| 欧美成年人视频网站欧美| 欧美成人一品| 欧美日韩综合精品| 国产精品免费视频观看| 国产精品视频999| 国产精品免费网站在线观看| 国产老女人精品毛片久久| 欧美高清成人| 欧美日韩国产麻豆| 国产精品久久久久aaaa九色| 国产精品伊人日日| 韩国av一区| 亚洲乱码国产乱码精品精| 国产精品一区二区欧美| 国产女优一区| 亚洲成人在线网站| 欧美日韩高清在线观看| 欧美精品导航| 国产精品啊啊啊| 国产亚洲精品自拍| 亚洲激情视频| 亚洲成人在线免费| 一区二区三区精密机械公司| 亚洲影院高清在线| 久久深夜福利免费观看| 欧美激情视频给我| 亚洲影院污污.| 欧美综合77777色婷婷| 久久综合色播五月| 欧美日韩国产影院| 国产亚洲一区二区三区| 亚洲免费观看视频| 亚洲免费电影在线| 久久国产欧美精品| 91久久综合| 久久成人免费| 欧美视频成人| 亚洲人成网站999久久久综合| 亚洲精品乱码久久久久久日本蜜臀 | 99综合在线| 免费国产一区二区| 亚洲天堂免费在线观看视频| 久久精品一区蜜桃臀影院| 欧美日韩在线精品| 在线观看一区视频| 久久av最新网址| 亚洲最新视频在线| 蜜桃久久精品乱码一区二区| 国产精品乱码一区二区三区| 亚洲精品欧美一区二区三区| 久久久久久久999| 亚洲午夜视频在线| 亚洲专区在线视频| 美女性感视频久久久| 夜夜嗨av色一区二区不卡| 亚洲素人在线| 亚洲黄网站在线观看| 一本色道**综合亚洲精品蜜桃冫| 国产精品一区二区男女羞羞无遮挡| 久久视频精品在线| 欧美视频一区二| 久久一区二区三区四区| 欧美日本韩国一区| 久久艳片www.17c.com| 欧美三区不卡| 欧美国产视频一区二区| 国产精品久久久久久久久久尿| 久久久伊人欧美| 国产精品夫妻自拍| 亚洲国产精品va在线观看黑人| 国产精品国产馆在线真实露脸 | 欧美婷婷在线| 久久综合久色欧美综合狠狠 | 欧美大学生性色视频| 国产精品视频久久久| 亚洲成人在线视频播放| 欧美精品一区二区三区高清aⅴ| 欧美影视一区| 欧美日韩一区免费| 91久久亚洲| 亚洲精品日产精品乱码不卡| 久久久国产一区二区三区| 欧美一区二区三区啪啪| 欧美日韩一卡| 亚洲精选成人| 在线综合亚洲欧美在线视频| 美国成人直播| 欧美96在线丨欧| 亚洲福利在线观看| 久久天天躁夜夜躁狠狠躁2022 | 欧美精品九九| 欧美国产视频日韩| 亚洲高清久久| 麻豆成人av| 亚洲电影在线观看| 亚洲精品网址在线观看| 欧美精品亚洲精品| 一区二区精品在线观看| 亚洲男女自偷自拍| 国产婷婷成人久久av免费高清| 亚洲欧美国产精品va在线观看| 亚洲欧美综合另类中字| 国产精品日韩高清| 欧美中文字幕| 欧美国产日韩精品| 亚洲婷婷综合久久一本伊一区| 欧美日韩午夜精品| 亚洲在线中文字幕| 久久视频在线看| 亚洲全黄一级网站| 欧美日韩www| 亚洲欧美久久| 美女图片一区二区| 日韩午夜视频在线观看| 欧美午夜精品电影| 欧美一区二区三区精品| 欧美成人精品在线观看| 日韩视频在线观看国产| 国产精品国产a| 久久精品欧洲| 亚洲人成欧美中文字幕| 亚洲欧美一区二区精品久久久| 国产在线观看91精品一区| 噜噜噜91成人网| 一本色道久久88精品综合| 久久av一区二区三区漫画| 1000部国产精品成人观看| 欧美日韩国产首页在线观看| 亚洲欧美综合一区| 亚洲人成在线播放网站岛国| 欧美一区国产二区| 亚洲精品五月天| 国产一区白浆| 欧美精品久久99| 欧美中文字幕在线| 一区二区国产在线观看| 国产精品成人播放| 久久国产婷婷国产香蕉| 亚洲国产精品一区二区www在线| 一本大道久久精品懂色aⅴ| 国产九区一区在线| 久久最新视频| 亚洲综合好骚| 欧美国产三级| 久久国产精品免费一区| 亚洲福利在线看| 国产欧美一区二区三区久久人妖 | 红桃视频欧美| 欧美精品三级在线观看| 久久久国产精品一区| 夜夜嗨av一区二区三区中文字幕 | 亚洲视频高清| 亚洲国产欧美国产综合一区 | 在线日韩精品视频| 国产精品美女视频网站| 欧美日本一区二区高清播放视频| 久久久国产精品亚洲一区| 亚洲欧美在线一区| 亚洲影院免费| 亚洲欧美激情精品一区二区| av成人免费在线观看|