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

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

內存崩潰的BUG (3)

Posted on 2009-04-01 13:35 S.l.e!ep.¢% 閱讀(1734) 評論(3)  編輯 收藏 引用 所屬分類: WinDbg

內存崩潰的BUG
內存崩潰的BUG (2)

在昨天的調試中,感謝JayZ
-----------------------------------------------------------------------------------------------------
地址段034bd000 - 00007000沒法訪問。

看調用棧0012e50c 0042ffc3 00000400 034c0fec 00000001 ws2_32!WSASend+0x61

WSASend的第二個參數為034c0fec很不幸的落在這個區間內。看WSASend的原型
int WSASend(
__in SOCKET s,
__in LPWSABUF lpBuffers,
__in DWORD dwBufferCount,
__out LPDWORD lpNumberOfBytesSent,
__in DWORD dwFlags,
__in LPWSAOVERLAPPED lpOverlapped,
__in LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine
);
顯然第二個參數lpBuffers的地址非法。

call stack frame往上就是你的代碼了:
0012f580 0040e577 0012f5bc 00000014 0012f58c xxx.exe+xxx-function

你需要在這里確認一下為什么傳出的lpBuffers指向一個錯誤的地址
-------------------------------------------------------------------------------------------------------

傳入 WSASend 的第二個參數 lpBuffers 確實指向了一個錯誤的地址,
用 knL + .frame + x
查看了?? xxx.exe+xxx-function???? 的局部變量,發現

-------------------------------------------------------------------------------------------------------
PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT;????? 發現??overlappedEx ?這個指針已經指向的內存是不對的
overlappedEx->IOOperation= WRITE;
overlappedEx->wsabuf.buf= (char *)malloc( nLen );
if( NULL == overlappedEx->wsabuf.buf )
{
delete overlappedEx;
return -1;
}

if(WSASend(m_socket,&(overlappedEx->wsabuf), 0x01,
&(overlappedEx->dwBytes), overlappedEx->dwFlags,
&(overlappedEx->Overlapped), NULL ) == SOCKET_ERROR)
{

在IOCP通知后,會 delete overlappedEx
-------------------------------------------------------------------------------------------------------

懷疑是不是 overlappedEx 這個指針的值被其它地方修改了?
于是在局數變量中定義了多一個變量,在 WSASend 調用前,加多這個語句,

PER_IO_CONTEXT* p? = overlappedEx;

等了幾個小時,再次重現問題,

用 knL + .frame + x
查看了?? xxx.exe+xxx-function???? 的局部變量,發現

p 的值跟 overlappedEx 還是相等的, 但它們指向的內存卻是

0366fe8c p = 0x03443fd8
0:010> !address 0x03443fd8
??? 03442000 : 03442000 - 00007000
??????????????????? Type???? 00000000
??????????????????? Protect? 00000001 PAGE_NOACCESS
??????????????????? State??? 00010000 MEM_FREE????????????????
??????????????????? Usage??? RegionUsageFree
0:010> dd 0x03443fd8
03443fd8? ???????? ???????? ???????? ????????
03443fe8? ???????? ???????? ???????? ????????
03443ff8? ???????? ???????? ???????? ????????
03444008? ???????? ???????? ???????? ????????
03444018? ???????? ???????? ???????? ????????
03444028? ???????? ???????? ???????? ????????
03444038? ???????? ???????? ???????? ????????
03444048? ???????? ???????? ???????? ????????

0:010> KB
ChildEBP RetAddr? Args to Child?????????????
0366edac 71a26294 00000668 03443fec 00000001 mswsock!WSPSend+0x243
0366ede8 00430027 00000668 03443fec 00000001 ws2_32!WSASend+0x77

初步結論是: 在執行到? mswsock!WSPSend+0x243 ,在 WSASend 上一層 new 出來的? PER_IO_CONTEXT 已經被 delete 了

Feedback

# re: 內存崩潰的BUG (3)   回復  更多評論   

2009-04-02 00:15 by JayZ
看如下輸出:
03442000 : 03442000 - 00007000
Type 00000000
Protect 00000001 PAGE_NOACCESS
State 00010000 MEM_FREE
Usage RegionUsageFree
這個內存段甚至已經不屬于Heap了(RegionUsageFree)。

建議放個條件斷點在VirtualFree里面,來看一下這個內存段什么時候被free掉的。從call stack上面應該很容易就能發現問題。

# re: 內存崩潰的BUG (3)   回復  更多評論   

2009-04-02 08:36 by guest
下內存斷點來監視,看看到底是被誰給改了。

# re: 內存崩潰的BUG (3)   回復  更多評論   

2009-04-02 12:17 by S.l.e!ep.¢%
-------------------------------------------------------------------------------------------------------
PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT; 發現 overlappedEx 這個指針已經指向的內存是不對的
overlappedEx->IOOperation= WRITE;
overlappedEx->wsabuf.buf= (char *)malloc( nLen );
if( NULL == overlappedEx->wsabuf.buf )
{
delete overlappedEx;
return -1;
}

if(WSASend(m_socket,&(overlappedEx->wsabuf), 0x01,
&dwBytes, 0,
&(overlappedEx->Overlapped), NULL ) == SOCKET_ERROR)
{

在IOCP通知后,會 delete overlappedEx
-------------------------------------------------------------------------------------------------------

今天直接用 Windbg 啟動程序,在 在IOCP通知后,會 delete overlappedEx 用 OutPutDebugString 打日志,
發現 在 delete overlappedEx 后,
WSASend 還會訪問到 overlappedEx
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产亚洲视频| 国产精品国产馆在线真实露脸| 看片网站欧美日韩| 久久久久久高潮国产精品视| 午夜精彩国产免费不卡不顿大片| 亚洲私人影院| 亚洲欧美国产77777| 亚洲国产福利在线| 久久理论片午夜琪琪电影网| 亚洲欧美一区二区激情| 亚洲免费在线电影| 久久精品综合| 最新热久久免费视频| 日韩一级欧洲| 久久精品一区二区| 欧美成人精品影院| 国产精品人人做人人爽人人添| 国产日韩高清一区二区三区在线| 国产一区二区精品久久99| 亚洲欧洲精品一区二区三区不卡| 午夜电影亚洲| 亚洲另类视频| 欧美成人影音| 亚洲国产电影| 久久蜜桃香蕉精品一区二区三区| 日韩视频在线免费| 欧美欧美天天天天操| 韩国视频理论视频久久| 亚洲亚洲精品三区日韩精品在线视频 | 欧美综合国产| 一区二区冒白浆视频| 欧美成年视频| 亚洲黄色在线| 亚洲黄页视频免费观看| 久久综合久久综合九色| 狠狠色狠狠色综合| 久久精品一区二区三区四区| 日韩视频一区二区| 免费观看久久久4p| 亚洲欧美精品在线观看| 国产精品国产三级国产aⅴ浪潮| 亚洲国产精品小视频| 免费在线日韩av| 欧美成人午夜激情视频| 亚洲第一区中文99精品| 91久久久在线| 国产精品v欧美精品v日韩精品| 一区二区不卡在线视频 午夜欧美不卡'| 美女精品国产| 欧美极品影院| 欧美在线精品免播放器视频| 亚洲欧美国产精品专区久久| 国产亚洲精品激情久久| 免费精品视频| 国产精品电影在线观看| 久久精品亚洲精品| 欧美精品久久天天躁| 久久久久久婷| 欧美色图五月天| 国产精品国产福利国产秒拍| 欧美一区国产一区| 另类酷文…触手系列精品集v1小说| 亚洲精品一区二区三区av| 亚洲在线日韩| 亚洲精品日韩一| 久久久久久97三级| 亚洲欧美日韩国产成人精品影院 | 亚洲精品久久久久中文字幕欢迎你| 在线亚洲自拍| 国产精品porn| 亚洲国产mv| 激情综合视频| 午夜精品久久久久| 欧美日本三级| 亚洲乱码国产乱码精品精可以看| 国内精品国语自产拍在线观看| 亚洲一区二区在线免费观看| 亚洲天堂免费观看| 欧美午夜不卡在线观看免费| 91久久精品一区| 久久精品国产成人| 亚洲精品一级| 一区二区久久久久久| 欧美人交a欧美精品| 亚洲激情在线| 亚洲香蕉视频| 国产午夜精品全部视频在线播放 | 亚洲国产精品久久久久| 欧美激情久久久久| 在线视频日韩| 亚洲人成网在线播放| 国产精品久久久久久久久婷婷| 亚洲人成人99网站| 欧美日韩一区国产| 久久国产精品久久久| 亚洲国产成人精品久久| 午夜精品久久久99热福利| 国产综合视频| 欧美日韩国语| 久久综合久久88| 久久精品一区二区三区不卡牛牛 | 久久久欧美精品| 9国产精品视频| 亚洲精品午夜| 亚洲国产精品一区二区www| 亚洲激情小视频| 欧美福利专区| 久久综合久色欧美综合狠狠| 亚洲女同精品视频| 亚洲精品之草原avav久久| 国产欧美日韩另类视频免费观看| 亚洲一区二区三区久久| 亚洲精品久久久久久一区二区| 国产综合欧美| 狠狠色噜噜狠狠狠狠色吗综合| 国产精品久久久久免费a∨大胸| 久久久亚洲国产美女国产盗摄| 亚洲一区二区在线播放| 亚洲午夜一区二区三区| 亚洲特黄一级片| 亚洲愉拍自拍另类高清精品| 亚洲男人影院| 欧美综合国产精品久久丁香| 久久久久久一区二区| 久久久www| 欧美午夜理伦三级在线观看| 国产精品家教| 91久久精品久久国产性色也91| 一区二区视频免费完整版观看| 精品99一区二区三区| 在线观看精品视频| 在线视频欧美一区| 久久日韩粉嫩一区二区三区| 欧美大片免费观看在线观看网站推荐| 亚洲高清免费视频| 在线视频你懂得一区| 久久精品91| 国产精品家庭影院| 亚洲精品一区久久久久久| 欧美一区1区三区3区公司| 免费观看日韩| 久久狠狠久久综合桃花| 欧美成人精品三级在线观看| 国产伦一区二区三区色一情| 亚洲日本一区二区| 另类春色校园亚洲| 久久精品日韩| 亚洲欧美日韩综合aⅴ视频| 欧美精品在线播放| 亚洲毛片播放| 亚洲精品日产精品乱码不卡| 乱中年女人伦av一区二区| 影音先锋亚洲电影| 欧美国产日韩xxxxx| 久久久精品视频成人| 在线日韩电影| 亚洲一区久久| 久久伊人免费视频| 久久先锋影音| 欧美一区二区三区日韩| 在线视频日本亚洲性| 欧美成人午夜免费视在线看片| 国产农村妇女精品一二区| 香蕉久久国产| 久久久999成人| 亚洲二区视频| 亚洲欧洲日本一区二区三区| 欧美日韩国产美| 午夜日韩在线观看| 久久亚洲精品欧美| 国产在线观看91精品一区| 久久国产视频网站| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲高清影视| 亚洲性图久久| 99热免费精品| 久久av在线| 亚洲欧美国产视频| 美女国产一区| 久久成人一区| 国产精品尤物福利片在线观看| 欧美黄色网络| 精品1区2区3区4区| 小黄鸭精品aⅴ导航网站入口 | 亚洲狼人精品一区二区三区| 国产精品大片wwwwww| 亚洲日本成人女熟在线观看| 韩国一区电影| 久久精品导航| 久久婷婷丁香| 黄色精品免费| 午夜精品久久久久久久99水蜜桃| 欧美另类亚洲| 最新高清无码专区| 亚洲三级影院| 欧美日韩一区视频| 99精品福利视频| 亚洲欧美日韩精品一区二区| 欧美午夜不卡影院在线观看完整版免费 | 亚洲网站在线播放|