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

一動不如一靜

C++博客 首頁 新隨筆 聯系 聚合 管理
  20 Posts :: 0 Stories :: 10 Comments :: 0 Trackbacks

#

http://www.microsoft.com/msj/0298/hood0298.aspx

posted @ 2008-02-23 18:10 一動不如一靜 閱讀(580) | 評論 (0)編輯 收藏

有時候我們的程序crash了,會出現一個crash界面提示我們在什么位置中斷了。我們如何根據這個中斷地址找到對應的行號呢?

要想達到這樣的目的,首先要進行一些工程屬性的配置。

c/c++->常規->調試信息格式->程序數據庫
c/c++->優化->優化->禁用
鏈接器->調試->生成調試信息->是
            ->生成映射文件->是
            ->映射文件名稱->$(OutDir)/$(ProjectName).map
            ->映射導出->是
            ->映射行->是

1    int main (int argc, char* argv[])
2   {
3       char * p = 0;
4       *p = 'c';
5       return 0;
6 }

當執行程序的時候,顯示“test1.exe中的0x0040100e處未處理的異常:0xc000005:寫入位置0x00000000時發生訪問沖突”


這個時候來看一下map文件。首先看到的是參考的加載地址: Preferred load address is 00400000

Timestamp is 4639462c (Thu May 03 10:17:16 2007)

 Preferred load address is 00400000

 Start         Length     Name                   Class
 0001:00000000 00003b58H .text                   CODE
 0002:00000000 000000c4H .idata$5                DATA
 0002:000000d0 00000c40H .rdata                  DATA
 0002:00000d10 00000048H .rdata$debug            DATA
 0002:00000d60 00000008H .rdata$sxdata           DATA
 0002:00000d68 00000004H .rtc$IAA                DATA
 0002:00000d6c 00000004H .rtc$IZZ                DATA
 0002:00000d70 00000004H .rtc$TAA                DATA
 0002:00000d74 00000004H .rtc$TZZ                DATA
 0002:00000d78 00000014H .idata$2                DATA
 0002:00000d8c 00000014H .idata$3                DATA
 0002:00000da0 000000c4H .idata$4                DATA
 0002:00000e64 00000366H .idata$6                DATA
 0002:000011ca 00000000H .edata                  DATA
 0003:00000000 00000004H .CRT$XCA                DATA
 0003:00000004 00000004H .CRT$XCAA               DATA
 0003:00000008 00000004H .CRT$XCZ                DATA
 0003:0000000c 00000004H .CRT$XIA                DATA
 0003:00000010 00000008H .CRT$XIC                DATA
 0003:00000018 00000004H .CRT$XIZ                DATA
 0003:0000001c 00000004H .CRT$XPA                DATA
 0003:00000020 00000004H .CRT$XPZ                DATA
 0003:00000024 00000004H .CRT$XTA                DATA
 0003:00000028 00000004H .CRT$XTZ                DATA
 0003:00000030 00000274H .data                   DATA
 0003:000002c0 00000598H .bss                    DATA

crash地址計算:calculation: crash_address - preferred_load_address - 0x1000
                            0x0040100e -0x00400000-0x1000=0x0000000e

接著在map中查找對應的obj

 Address         Publics by Value              Rva+Base     Lib:Object

 0000:00000000       __except_list              00000000     <absolute>
 0000:00000002       ___safe_se_handler_count   00000002     <absolute>
 0001:00000000       _main                      00401000 f   test1.obj
 0001:00000017       __amsg_exit                00401017 f   LIBC:crt0.obj
 0001:0000003c       _mainCRTStartup            0040103c f   LIBC:crt0.obj
 0001:00000203       ___crtExitProcess          00401203 f   LIBC:crt0dat.obj


最后根據obj和計算的值在map中找第一個小于我們所計算的值的位置

Line numbers for .\release\test1.obj(d:\test\test1\test1\test1.cpp) segment .text

     2 0001:00000000     3 0001:00000004     4 0001:0000000b     5 0001:00000011

然后在.map中查找第一個小于我們所計算的值的位置

所以我們的中斷位置是在第4行

posted @ 2007-05-03 10:44 一動不如一靜 閱讀(1604) | 評論 (3)編輯 收藏

Hummingbird connectivity
posted @ 2007-03-07 23:29 一動不如一靜 閱讀(228) | 評論 (0)編輯 收藏

首先用~*kb,察看所有的線程
然后尋找Filter關鍵字所在的線程,假設出問題的線程為12,.

首先將線程2設置為當前線程: ~2s
因為XcpFilter的結構體中,第2個參數表示異常信息的指針,第3個參數是上下文的指針。
假設args to child
    0x0001 0xb5f78 0x45235

執行.exr 0xb5f78
執行.cxr 0x45235

執行.kb就可以還原堆棧信息了

posted @ 2007-03-07 23:17 一動不如一靜 閱讀(5000) | 評論 (0)編輯 收藏

     摘要: ACE_TP_Reactor::ACE_TP_Reactor?(size_t?max_number_of_handles,???????????????????????????????? int ?restart,????????????????????????????????ACE_Sig_Handler? * sh,???????????????????...  閱讀全文
posted @ 2007-02-25 20:41 一動不如一靜 閱讀(2289) | 評論 (0)編輯 收藏

     摘要: 首先從定義一個reactor開始。ACE_TP_Reactor select_reactor_one(g_unOneMaxHandle, 0, 0, 0, 1); 上面的這句話觸發了一下的一些行為。主要就是給event_handlers_分配了內存。這里就決定了你能支持多少條連接 int ACE_Select_React...  閱讀全文
posted @ 2007-02-24 20:30 一動不如一靜 閱讀(1788) | 評論 (0)編輯 收藏

?

/* *******************************************************************
*?Copyright?(c)?2006,study-record?home
*?All?rights?reservered.
*
*?文件名稱?:?littersize.cpp?
*?摘????要?:?這個例子主要是用來驗證這樣一個問題。當我們程序中有n個reactor的時候,是否就意味著我們支持n*FD_SETSIZE連接.
???????????????????為了驗證這個問題,我們傳遞一個大小為2的值給ACE_Select_Reactor的構造函數。看是否是只支持2個連接?
???????????????????驗證結果表明:在本例子中,由于acceptor注冊用掉了一個,而我們給定的最大的handle數為2,所以只能接受一個連接。
???????????????????在命令行下輸入:telnet?127.0.0.1?1234?,在我們第二次輸入時,
???????????????????在調用int?nRet?=?m_Reactor->register_handler(pEvent,?ACE_Event_Handler::READ_MASK);的時候一定會失敗。
???????????????????但是在命令行下輸入:telnet?127.0.0.1?2345?,在我們第三次輸入的時候,調用register_handler的時候才會失敗
???????????????????但是這樣的一段代碼存在高cpu的問題,也就是當把客戶端關調的時候,cpu占用率會很高?想想看,為什么呢?
???????????????????本代碼只是為了驗證一些東西,有很多不合理的地方,請務仿照。
*
*?當前版本?:?1.0
*?作????者?:?study-record???2007-2-22
*
********************************************************************
*/


#include?
" ace/Thread_Manager.h "
#include?
" ace/Select_Reactor.h "
#include?
" ace/Reactor.h "
#include?
" ace/Event_Handler.h "
#include?
" ace/SOCK_Acceptor.h "
#include?
" ace/SOCK_Stream.h "
#include?
" ace/INET_Addr.h "

const ?size_t?g_unOneMaxHandle? = ? 2 ;
const ?size_t?g_unTwoMaxhandle? = ? 4 ;


static ?ACE_THR_FUNC_RETURN?event_loop_one?( void ? * arg)?
{
????ACE_Reactor?
* reacator? = ?static_cast < ACE_Reactor? *> (arg);

????reacator
-> owner(ACE_Thread::self());
????reacator
-> run_reactor_event_loop();
????
return ? 0 ;

}

static ?ACE_THR_FUNC_RETURN?event_loop_two?( void ? * arg)?
{
????ACE_Reactor?
* reacator? = ?static_cast < ACE_Reactor? *> (arg);

????reacator
-> owner(ACE_Thread::self());
????reacator
-> run_reactor_event_loop();
????
return ? 0 ;
}


class ?TestHandleEvent:? public ?ACE_Event_Handler
{
public :
????
virtual ? int ?handle_input?(ACE_HANDLE?fd? = ?ACE_INVALID_HANDLE)
????
{
????????ACE_DEBUG((LM_DEBUG,?
" TestHandleEvent::handle_input\n " ));
????????
return ? 0 ;
????}
;
????
virtual ? int ?handle_close?(ACE_HANDLE?handle,?ACE_Reactor_Mask?close_mask)
????
{
????????
????????ACE_DEBUG((LM_DEBUG,?
" TestHandleEvent::handle_close\n " ));
????????delete?
this ;
????????
return ? 0 ;

????}
;
????ACE_HANDLE?get_handle(
void )? const ?
????
{
????????
return ?peer.get_handle();
????}


public :
????ACE_SOCK_Stream?peer;

}
;
class ?TestAcceptor?:? public ?ACE_Event_Handler
{
public :
????
virtual ? int ?handle_input?(ACE_HANDLE?fd? = ?ACE_INVALID_HANDLE)
????
{
????????
????????TestHandleEvent
* ?pEvent? = ? new ?TestHandleEvent;
????????acceptor.accept(pEvent
-> peer);
????????
int ?nRet? = ?m_Reactor -> register_handler(pEvent,?ACE_Event_Handler::READ_MASK);
????????
if ?( - 1 ? == ?nRet)
????????
{
????????????delete?pEvent;
????????????pEvent?
= ?NULL;
????????}


????????
return ? 0 ;
????}
;
????
virtual ? int ?handle_close?(ACE_HANDLE?handle,?ACE_Reactor_Mask?close_mask)
????
{
????????ACE_DEBUG((LM_DEBUG,?
" TestAcceptor::handle_close\n " ));
????????acceptor.close();
????????delete?
this ;

????????
return ? 0 ;

????}
;
????
????
????TestAcceptor(ACE_Reactor
* ?reactor):m_Reactor(reactor)
????
{
????????
????}
;
????
int ?open(unsigned? short ?usport)
????
{
????????ACE_INET_Addr?addr(usport);
????????acceptor.open(addr);
????????
return ?m_Reactor -> register_handler( this ,?ACE_Event_Handler::ACCEPT_MASK);

????}
;
????ACE_HANDLE?get_handle(
void )? const ?
????
{
????????
????????
return ?acceptor.get_handle();
????}

public :
????ACE_SOCK_Acceptor?acceptor;
????ACE_Reactor
* ?m_Reactor;

}
;


int ?main?( int ?argc,? char ? * argv[])
{
????

????ACE_Select_Reactor?select_reactor_one(g_unOneMaxHandle,?
0 ,? 0 ,? 0 ,? 1 );
????ACE_Reactor
* ?reactor_one? = ? new ?ACE_Reactor( & select_reactor_one);

????ACE_Select_Reactor?select_reactor_two(g_unTwoMaxhandle,?
0 ,? 0 ,? 0 ,? 1 );
????ACE_Reactor
* ?reactor_two? = ? new ?ACE_Reactor( & select_reactor_two);

????TestAcceptor?test_acceptor(reactor_one);
????test_acceptor.open(
1234 );

????TestAcceptor?test_acceptorw(reactor_two);
????test_acceptorw.open(
2345 );
????
????
????ACE_Thread_Manager::instance()
-> spawn(event_loop_one,?reactor_one);
????ACE_Thread_Manager::instance()
-> spawn(event_loop_two,?reactor_two);

????
return ?ACE_Thread_Manager::instance() -> wait();
}
posted @ 2007-02-22 23:25 一動不如一靜 閱讀(864) | 評論 (0)編輯 收藏

近來在工作中總是會有一些dump文件需要分析,但是自己對windug十分陌生。所以就想自己產生幾個coredump文件,然后學習著用windug進行分析。雖然有了這個想法,但是不知道怎么才能在windows上產生coredump文件。于是抱著試試的想法,搜索了一下,結果還真讓我給搜到了。
在以下的這個網址講述了如何在xp和2000上如何設置?
http://publib.boulder.ibm.com/infocenter/wasinfo/v4r0/index.jsp?topic=/com.ibm.support.was40.doc/html/Crash/swg21113013.html

現在我呢,就做了搬運工,搬到這里^_^。

Solution
  1. Open a command prompt window.

  2. Enter the command drwtsn32.exe.

    The following window will display:
    • For Windows 2000:



    • For Windows XP:



  3. In the Log File Path field, type the location to where you want the DrWatson log to be stored.

  4. In the Crash Dump field, type the file name and location where you want the user.dmp file to be stored.

  5. Make sure that the following options are selected:
    1. Dump Symbol Table
    2. Dump All Thread Contents
    3. Visual Notification
    4. Create Crash Dump File

  6. If you are running Windows XP, set Crash Dump Type to NT4 Full Compatible.

  7. From a command prompt, enter drwtsn32 -i to re-enable Dr. Watson as your default Windows debugger. This will make the necessary changes in the Windows registry.
?


?






posted @ 2006-12-10 12:52 一動不如一靜 閱讀(3980) | 評論 (0)編輯 收藏

1.定位進程到底是掛在哪里
  psstack 進程ID > 文件名稱
??? ?? cat 文件名稱 | c++filt > 其他的文件   
2.?? snoopy抓包
???? a.先用ifconfig查出設備名稱,假設為bge0
??? b. snoop -d bge0 -o 文件文成 目的機器的IP地址
??? c.snoopy from ip地址 to ip地址
  
?? 3.抓dump包之后用windug分析。這里的學問就大了。目前正在學習中
posted @ 2006-12-09 20:04 一動不如一靜 閱讀(417) | 評論 (0)編輯 收藏

一直對異步IO懷有恐懼之心,所以到現在也沒有仔細的去研究過,但是老師怎么告訴我們說要用于面對困難,所以決定坐下來研究一下,看看到底有多高深,不向困難低頭^_^

資源:http://www.zahui.com/html/9/35437.htm
posted @ 2006-10-07 13:57 一動不如一靜 閱讀(535) | 評論 (0)編輯 收藏

僅列出標題
共2頁: 1 2 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品午夜视频| 欧美一级二级三级蜜桃| 久久夜精品va视频免费观看| 一本色道久久综合精品竹菊| 精品1区2区| 国产精品嫩草99av在线| 欧美成人视屏| 久久久夜夜夜| 亚洲欧美日韩国产一区| 日韩网站免费观看| 欧美激情中文字幕在线| 另类综合日韩欧美亚洲| 久久www成人_看片免费不卡| 亚洲影视在线播放| 妖精视频成人观看www| 亚洲国产精品久久精品怡红院 | 国产精品视频观看| 欧美精彩视频一区二区三区| 久久久人成影片一区二区三区 | 亚洲网站在线看| 亚洲日本电影在线| 亚洲国产成人不卡| 伊人春色精品| 黄色小说综合网站| 国产一区二区三区在线免费观看| 国产精品久久看| 欧美性感一类影片在线播放| 欧美日韩精品免费观看视一区二区| 老司机午夜精品视频在线观看| 久久se精品一区二区| 欧美在线一区二区三区| 欧美在线看片a免费观看| 亚洲欧洲av一区二区| 亚洲一区二区免费视频| 亚洲男女自偷自拍图片另类| 亚洲午夜久久久久久久久电影网| 国产精品99久久久久久久久| 亚洲一区二区三区在线| 亚洲视频一二三| 亚洲永久精品大片| 亚洲欧美日韩国产一区二区三区 | 欧美一区亚洲| 欧美在线精品一区| 久久久亚洲欧洲日产国码αv| 久久精品国产精品| 老司机一区二区| 亚洲高清资源综合久久精品| 亚洲高清一区二| 日韩亚洲综合在线| 亚洲一区高清| 欧美与黑人午夜性猛交久久久| 久久久久久97三级| 免费欧美日韩| 欧美三级午夜理伦三级中视频| 国产精品va| 国产亚洲成av人片在线观看桃| 影音先锋久久| 亚洲精品一线二线三线无人区| 在线亚洲免费视频| 欧美一区二区三区婷婷月色 | 欧美在线播放一区二区| 久久久青草婷婷精品综合日韩| 欧美激情va永久在线播放| 欧美日韩亚洲成人| 国产欧美日韩另类视频免费观看| 国语自产在线不卡| 亚洲激情av在线| 亚洲一区二区三区视频| 久久精品伊人| 亚洲国产一区二区三区青草影视 | 欧美fxxxxxx另类| 欧美午夜精品久久久久久人妖| 国产日韩欧美一区二区| 亚洲国产精品www| 亚洲制服少妇| 欧美成人有码| 亚洲一区二区成人在线观看| 久久网站热最新地址| 欧美日韩亚洲91| 一区二区三区在线免费播放| 在线视频免费在线观看一区二区| 久久久久久97三级| 亚洲美女在线一区| 久久久91精品国产| 欧美午夜片在线免费观看| 激情一区二区| 亚洲欧美www| 亚洲第一中文字幕| 欧美一级视频| 欧美四级伦理在线| 亚洲啪啪91| 久久精品一二三区| 一本色道久久综合| 噜噜噜噜噜久久久久久91 | 经典三级久久| 午夜精品视频一区| 91久久久国产精品| 久久深夜福利| 国产日韩欧美在线| 亚洲专区一二三| 亚洲国产精品福利| 久久久久久久综合| 国产日本欧美一区二区三区在线| 99精品热6080yy久久| 欧美91精品| 久久精品久久综合| 国产欧美日韩专区发布| 亚洲欧美欧美一区二区三区| 亚洲精品欧美一区二区三区| 另类天堂av| 在线播放一区| 久久久久久久高潮| 亚洲欧美日韩天堂一区二区| 国产精品狠色婷| 一区二区三区精品视频| 91久久亚洲| 欧美成人自拍| 亚洲欧洲久久| 欧美黄色网络| 麻豆久久婷婷| 亚洲国产第一| 牛夜精品久久久久久久99黑人| 久久精精品视频| 国产亚洲电影| 久久久国产一区二区三区| 亚洲欧美国产精品专区久久| 国产精品乱子乱xxxx| 亚洲一区二区三区国产| 亚洲视频999| 国产精品二区在线| 午夜久久福利| 亚洲综合日韩| 国产午夜精品理论片a级大结局| 欧美一区二区网站| 香蕉国产精品偷在线观看不卡| 国产视频一区免费看| 久久高清国产| 久久久久国产精品一区二区| 在线欧美日韩国产| 欧美大片91| 欧美精品三级在线观看| 制服诱惑一区二区| 亚洲已满18点击进入久久 | 一区二区免费在线播放| 在线亚洲一区观看| 国产精品私拍pans大尺度在线| 欧美影院一区| 久久久精品一品道一区| 最新国产成人在线观看| 日韩视频在线播放| 国产精品视频导航| 久久综合狠狠综合久久综青草| 蜜臀av国产精品久久久久| 一本综合久久| 亚洲欧美日本精品| 永久555www成人免费| 最新日韩欧美| 国产精品日韩欧美| 葵司免费一区二区三区四区五区| 欧美va亚洲va香蕉在线| 国产精品99久久久久久人| 性色一区二区三区| 91久久精品国产91久久性色tv| 99在线|亚洲一区二区| 国产欧美日韩麻豆91| 亚洲成人在线视频网站| 欧美午夜精彩| 蜜臀av性久久久久蜜臀aⅴ| 欧美啪啪成人vr| 久久99伊人| 欧美成人日本| 亚久久调教视频| 欧美www在线| 久久国产高清| 欧美精品九九99久久| 欧美在线观看一二区| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲深夜福利视频| 久久久久久久999精品视频| 亚洲一二三区在线观看| 久久米奇亚洲| 亚洲欧美日韩国产中文在线| 毛片一区二区三区| 先锋a资源在线看亚洲| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久久久久久久久久久久9999| 一卡二卡3卡四卡高清精品视频| 欧美一区三区二区在线观看| 夜夜精品视频| 久久久久久久久久久一区| 亚洲女人天堂成人av在线| 欧美成人一区二区三区片免费| 久久精彩视频| 欧美性猛交xxxx乱大交退制版| 欧美大尺度在线| 国产一区二区三区在线免费观看 | 国产精品裸体一区二区三区| 亚洲国产精品激情在线观看| 国产三区二区一区久久| 99精品视频免费全部在线|