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

S.l.e!ep.¢%

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

內(nèi)存崩潰的BUG (3)

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

內(nèi)存崩潰的BUG
內(nèi)存崩潰的BUG (2)

在昨天的調(diào)試中,感謝JayZ
-----------------------------------------------------------------------------------------------------
地址段034bd000 - 00007000沒(méi)法訪(fǎng)問(wèn)。

看調(diào)用棧0012e50c 0042ffc3 00000400 034c0fec 00000001 ws2_32!WSASend+0x61

WSASend的第二個(gè)參數(shù)為034c0fec很不幸的落在這個(gè)區(qū)間內(nèi)。看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
);
顯然第二個(gè)參數(shù)lpBuffers的地址非法。

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

你需要在這里確認(rèn)一下為什么傳出的lpBuffers指向一個(gè)錯(cuò)誤的地址
-------------------------------------------------------------------------------------------------------

傳入 WSASend 的第二個(gè)參數(shù) lpBuffers 確實(shí)指向了一個(gè)錯(cuò)誤的地址,
用 knL + .frame + x
查看了?? xxx.exe+xxx-function???? 的局部變量,發(fā)現(xiàn)

-------------------------------------------------------------------------------------------------------
PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT;????? 發(fā)現(xiàn)??overlappedEx ?這個(gè)指針已經(jīng)指向的內(nèi)存是不對(duì)的
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通知后,會(huì) delete overlappedEx
-------------------------------------------------------------------------------------------------------

懷疑是不是 overlappedEx 這個(gè)指針的值被其它地方修改了?
于是在局?jǐn)?shù)變量中定義了多一個(gè)變量,在 WSASend 調(diào)用前,加多這個(gè)語(yǔ)句,

PER_IO_CONTEXT* p? = overlappedEx;

等了幾個(gè)小時(shí),再次重現(xiàn)問(wèn)題,

用 knL + .frame + x
查看了?? xxx.exe+xxx-function???? 的局部變量,發(fā)現(xiàn)

p 的值跟 overlappedEx 還是相等的, 但它們指向的內(nèi)存卻是

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

初步結(jié)論是: 在執(zhí)行到? mswsock!WSPSend+0x243 ,在 WSASend 上一層 new 出來(lái)的? PER_IO_CONTEXT 已經(jīng)被 delete 了

Feedback

# re: 內(nèi)存崩潰的BUG (3)   回復(fù)  更多評(píng)論   

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

建議放個(gè)條件斷點(diǎn)在VirtualFree里面,來(lái)看一下這個(gè)內(nèi)存段什么時(shí)候被free掉的。從call stack上面應(yīng)該很容易就能發(fā)現(xiàn)問(wèn)題。

# re: 內(nèi)存崩潰的BUG (3)   回復(fù)  更多評(píng)論   

2009-04-02 08:36 by guest
下內(nèi)存斷點(diǎn)來(lái)監(jiān)視,看看到底是被誰(shuí)給改了。

# re: 內(nèi)存崩潰的BUG (3)   回復(fù)  更多評(píng)論   

2009-04-02 12:17 by S.l.e!ep.¢%
-------------------------------------------------------------------------------------------------------
PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT; 發(fā)現(xiàn) overlappedEx 這個(gè)指針已經(jīng)指向的內(nèi)存是不對(duì)的
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通知后,會(huì) delete overlappedEx
-------------------------------------------------------------------------------------------------------

今天直接用 Windbg 啟動(dòng)程序,在 在IOCP通知后,會(huì) delete overlappedEx 用 OutPutDebugString 打日志,
發(fā)現(xiàn) 在 delete overlappedEx 后,
WSASend 還會(huì)訪(fǎng)問(wèn)到 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>
            国产日韩亚洲欧美精品| 久久久久久久高潮| 欧美日韩成人综合| 日韩视频免费看| 亚洲日本欧美日韩高观看| 麻豆视频一区二区| 日韩亚洲欧美在线观看| 日韩亚洲欧美成人| 国产欧美日韩在线观看| 老司机67194精品线观看| 免费观看在线综合色| 一本色道**综合亚洲精品蜜桃冫| 亚洲免费电影在线| 国产日韩精品久久| 亚洲国产高清一区| 国产精品综合| 欧美大片va欧美在线播放| 欧美日本一道本| 欧美在线免费看| 久久综合狠狠综合久久综合88| 日韩天堂在线观看| 亚洲欧美日韩在线观看a三区| 狠狠综合久久av一区二区小说 | 在线观看中文字幕不卡| 亚洲美女精品久久| 国产亚洲激情视频在线| 亚洲韩国一区二区三区| 国产精品乱子乱xxxx| 欧美大秀在线观看| 欧美一区二区视频网站| 美国三级日本三级久久99| 欧美日韩国产一级片| 久久精品国产69国产精品亚洲| 美女国内精品自产拍在线播放| 亚洲一区二区三区中文字幕在线 | 免费不卡在线视频| 欧美午夜不卡视频| 欧美成人午夜激情| 国产亚洲精品久久久久动| 亚洲高清免费| 国模叶桐国产精品一区| 日韩一区二区精品视频| 亚洲二区免费| 欧美综合二区| 久久www成人_看片免费不卡| 欧美日韩国产一级| 亚洲国产另类精品专区 | 欧美体内she精视频| 欧美成年人视频网站| 国产亚洲精品久久久| 亚洲欧美电影在线观看| 亚洲伊人一本大道中文字幕| 欧美成人在线影院| 免费在线亚洲欧美| 激情欧美日韩一区| 欧美在线亚洲在线| 午夜在线电影亚洲一区| 欧美午夜无遮挡| 日韩一级在线| 亚洲综合三区| 国产精品色婷婷| 亚洲午夜久久久久久久久电影院| 一本一本久久| 欧美日韩中文字幕| 中文精品视频| 亚洲欧美日韩另类精品一区二区三区| 欧美日韩一区二区三区在线视频 | 免费在线国产精品| 亚洲成人资源网| 欧美aⅴ一区二区三区视频| 欧美成人国产一区二区| 亚洲电影在线播放| 麻豆成人综合网| 欧美激情一区二区久久久| 亚洲国产婷婷| 欧美久久久久久蜜桃| 一片黄亚洲嫩模| 亚洲欧美在线磁力| 国产在线观看91精品一区| 久久久青草青青国产亚洲免观| 久久成人免费日本黄色| 一区视频在线播放| 欧美顶级少妇做爰| 一本色道久久综合一区| 欧美伊人久久大香线蕉综合69| 国产亚洲精品一区二区| 久久久久高清| 亚洲国产小视频| 亚洲自拍偷拍网址| 国产一区二区日韩精品欧美精品| 欧美影院在线播放| 欧美黄色网络| 国产一区二区三区电影在线观看| 久久综合九色综合久99| 亚洲美女av在线播放| 欧美四级在线观看| 久久精品色图| 99re热这里只有精品免费视频| 午夜视黄欧洲亚洲| 亚洲黄色免费| 国产欧美日韩综合一区在线观看| 蜜桃av综合| 亚洲欧美日韩综合aⅴ视频| 欧美成人黄色小视频| 亚洲欧美综合国产精品一区| 一区视频在线播放| 国产精品免费看片| 欧美电影免费观看高清完整版| 亚洲欧美日韩人成在线播放| 亚洲电影成人| 久久久久国产一区二区| 宅男在线国产精品| 亚洲第一网站| 国产视频在线一区二区| 欧美日韩一区在线播放| 久久先锋资源| 欧美在线日韩精品| 亚洲视频你懂的| 91久久精品久久国产性色也91| 久久精品亚洲精品| 亚洲欧美国产毛片在线| 99re6热在线精品视频播放速度| 国产主播一区二区三区| 国产精品久久国产精麻豆99网站| 老司机午夜精品视频在线观看| 性欧美激情精品| 亚洲欧美国产77777| 一区二区毛片| 99国产精品| 99xxxx成人网| 一本一本久久| 一本久久知道综合久久| 亚洲激情另类| 亚洲国产一区二区三区a毛片| 久久亚洲国产成人| 久久久久久久久久久一区| 欧美一区二区三区成人| 亚洲伊人伊色伊影伊综合网| 亚洲线精品一区二区三区八戒| 99国产精品国产精品久久| 亚洲三级观看| 日韩亚洲在线| 亚洲视频在线二区| 亚洲欧美日韩一区二区在线| 国产精品99久久久久久久久| 99re66热这里只有精品4| 9l国产精品久久久久麻豆| 99精品视频一区| 亚洲调教视频在线观看| 午夜日韩电影| 久久成人免费电影| 免费不卡视频| 亚洲精品韩国| 一本到高清视频免费精品| 一区二区冒白浆视频| 亚洲一区二区伦理| 亚洲欧美综合国产精品一区| 欧美一区二区在线播放| 久久色中文字幕| 欧美国产欧美亚洲国产日韩mv天天看完整 | 欧美精品一区二区久久婷婷| 欧美日韩成人在线播放| 欧美亚洲第一区| 国产免费亚洲高清| 激情视频一区二区| 亚洲精品久久久久久久久| 亚洲视频专区在线| 欧美一区二区视频在线| 欧美插天视频在线播放| 一本色道久久88综合日韩精品| 亚洲午夜电影在线观看| 久久av资源网| 欧美精品激情| 国产日韩在线看片| 91久久精品网| 欧美在线免费观看亚洲| 亚洲国产精品尤物yw在线观看| 亚洲视频一区二区在线观看| 欧美在线黄色| 欧美视频中文字幕在线| 国产综合色精品一区二区三区| 亚洲人成艺术| 久久精品在线| 亚洲国产精品免费| 午夜久久黄色| 欧美日韩少妇| 在线观看不卡av| 先锋a资源在线看亚洲| 亚洲国产美国国产综合一区二区| 亚洲一区二区三| 欧美精品亚洲二区| 国产综合久久久久久| 亚洲男人的天堂在线aⅴ视频| 久久99在线观看| 一本一本久久| 欧美另类99xxxxx| 精品动漫3d一区二区三区免费| 亚洲欧美文学| 一区二区电影免费在线观看| 久久久噜噜噜久久中文字幕色伊伊|