• <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>

            S.l.e!ep.¢%

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

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

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

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

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

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

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

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

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

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

            -------------------------------------------------------------------------------------------------------
            PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT;????? 發(fā)現(xiàn)??overlappedEx ?這個指針已經(jīng)指向的內(nèi)存是不對的
            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 這個指針的值被其它地方修改了?
            于是在局數(shù)變量中定義了多一個變量,在 WSASend 調(diào)用前,加多這個語句,

            PER_IO_CONTEXT* p? = overlappedEx;

            等了幾個小時,再次重現(xià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

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

            Feedback

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

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

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

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

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

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

            2009-04-02 12:17 by S.l.e!ep.¢%
            -------------------------------------------------------------------------------------------------------
            PER_IO_CONTEXT* overlappedEx=new PER_IO_CONTEXT; 發(fā)現(xiàn) overlappedEx 這個指針已經(jīng)指向的內(nèi)存是不對的
            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 打日志,
            發(fā)現(xiàn) 在 delete overlappedEx 后,
            WSASend 還會訪問到 overlappedEx
            狠狠久久综合伊人不卡| 午夜欧美精品久久久久久久| 国产成人精品久久综合| 一本色道久久综合狠狠躁篇| 精品乱码久久久久久久| 国产毛片久久久久久国产毛片| 婷婷久久五月天| 91超碰碰碰碰久久久久久综合| 亚洲国产日韩欧美久久| 国产69精品久久久久9999| 亚洲欧美日韩久久精品第一区| 国产综合精品久久亚洲| 久久久噜噜噜www成人网| 亚洲欧美久久久久9999| 国产精品伊人久久伊人电影| 久久久无码一区二区三区| 久久中文精品无码中文字幕| 色综合久久88色综合天天| 久久A级毛片免费观看| 久久久SS麻豆欧美国产日韩| 久久www免费人成精品香蕉| 久久久久99精品成人片欧美| 国产精品久久久久久五月尺| 国内精品久久久久久麻豆| 狠狠色丁香久久综合婷婷| 欧美亚洲色综久久精品国产| 久久免费看黄a级毛片| 久久无码高潮喷水| 欧美亚洲国产精品久久| 奇米影视7777久久精品人人爽| 99久久久久| 久久久久黑人强伦姧人妻| 精品无码人妻久久久久久| 国产L精品国产亚洲区久久| 99久久精品国产一区二区| 91亚洲国产成人久久精品网址| 久久综合九色综合97_久久久| 亚洲综合久久综合激情久久 | 国内精品久久久久伊人av| 日韩精品久久久久久免费| 麻豆AV一区二区三区久久|