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

一動(dòng)不如一靜

C++博客 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
  20 Posts :: 0 Stories :: 10 Comments :: 0 Trackbacks

2008年2月23日 #

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

posted @ 2008-02-23 18:10 一動(dòng)不如一靜 閱讀(576) | 評(píng)論 (0)編輯 收藏

2007年5月3日 #

有時(shí)候我們的程序crash了,會(huì)出現(xiàn)一個(gè)crash界面提示我們?cè)谑裁次恢弥袛嗔恕N覀內(nèi)绾胃鶕?jù)這個(gè)中斷地址找到對(duì)應(yīng)的行號(hào)呢?

要想達(dá)到這樣的目的,首先要進(jìn)行一些工程屬性的配置。

c/c++->常規(guī)->調(diào)試信息格式->程序數(shù)據(jù)庫(kù)
c/c++->優(yōu)化->優(yōu)化->禁用
鏈接器->調(diào)試->生成調(diào)試信息->是
            ->生成映射文件->是
            ->映射文件名稱->$(OutDir)/$(ProjectName).map
            ->映射導(dǎo)出->是
            ->映射行->是

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

當(dāng)執(zhí)行程序的時(shí)候,顯示“test1.exe中的0x0040100e處未處理的異常:0xc000005:寫入位置0x00000000時(shí)發(fā)生訪問(wèn)沖突”


這個(gè)時(shí)候來(lái)看一下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地址計(jì)算:calculation: crash_address - preferred_load_address - 0x1000
                            0x0040100e -0x00400000-0x1000=0x0000000e

接著在map中查找對(duì)應(yīng)的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


最后根據(jù)obj和計(jì)算的值在map中找第一個(gè)小于我們所計(jì)算的值的位置

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中查找第一個(gè)小于我們所計(jì)算的值的位置

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

posted @ 2007-05-03 10:44 一動(dòng)不如一靜 閱讀(1592) | 評(píng)論 (3)編輯 收藏

2007年3月7日 #

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

首先用~*kb,察看所有的線程
然后尋找Filter關(guān)鍵字所在的線程,假設(shè)出問(wèn)題的線程為12,.

首先將線程2設(shè)置為當(dāng)前線程: ~2s
因?yàn)閄cpFilter的結(jié)構(gòu)體中,第2個(gè)參數(shù)表示異常信息的指針,第3個(gè)參數(shù)是上下文的指針。
假設(shè)args to child
    0x0001 0xb5f78 0x45235

執(zhí)行.exr 0xb5f78
執(zhí)行.cxr 0x45235

執(zhí)行.kb就可以還原堆棧信息了

posted @ 2007-03-07 23:17 一動(dòng)不如一靜 閱讀(4985) | 評(píng)論 (0)編輯 收藏

2007年2月25日 #

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

2007年2月24日 #

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

2007年2月22日 #

?

/* *******************************************************************
*?Copyright?(c)?2006,study-record?home
*?All?rights?reservered.
*
*?文件名稱?:?littersize.cpp?
*?摘????要?:?這個(gè)例子主要是用來(lái)驗(yàn)證這樣一個(gè)問(wèn)題。當(dāng)我們程序中有n個(gè)reactor的時(shí)候,是否就意味著我們支持n*FD_SETSIZE連接.
???????????????????為了驗(yàn)證這個(gè)問(wèn)題,我們傳遞一個(gè)大小為2的值給ACE_Select_Reactor的構(gòu)造函數(shù)。看是否是只支持2個(gè)連接?
???????????????????驗(yàn)證結(jié)果表明:在本例子中,由于acceptor注冊(cè)用掉了一個(gè),而我們給定的最大的handle數(shù)為2,所以只能接受一個(gè)連接。
???????????????????在命令行下輸入:telnet?127.0.0.1?1234?,在我們第二次輸入時(shí),
???????????????????在調(diào)用int?nRet?=?m_Reactor->register_handler(pEvent,?ACE_Event_Handler::READ_MASK);的時(shí)候一定會(huì)失敗。
???????????????????但是在命令行下輸入:telnet?127.0.0.1?2345?,在我們第三次輸入的時(shí)候,調(diào)用register_handler的時(shí)候才會(huì)失敗
???????????????????但是這樣的一段代碼存在高cpu的問(wèn)題,也就是當(dāng)把客戶端關(guān)調(diào)的時(shí)候,cpu占用率會(huì)很高?想想看,為什么呢?
???????????????????本代碼只是為了驗(yàn)證一些東西,有很多不合理的地方,請(qǐng)務(wù)仿照。
*
*?當(dāng)前版本?:?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 一動(dòng)不如一靜 閱讀(861) | 評(píng)論 (0)編輯 收藏

2006年12月10日 #

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

現(xiàn)在我呢,就做了搬運(yùn)工,搬到這里^_^。

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 一動(dòng)不如一靜 閱讀(3972) | 評(píng)論 (0)編輯 收藏

2006年12月9日 #

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

2006年10月7日 #

一直對(duì)異步IO懷有恐懼之心,所以到現(xiàn)在也沒(méi)有仔細(xì)的去研究過(guò),但是老師怎么告訴我們說(shuō)要用于面對(duì)困難,所以決定坐下來(lái)研究一下,看看到底有多高深,不向困難低頭^_^

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

僅列出標(biāo)題  下一頁(yè)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品女主播在线观看| 久热爱精品视频线路一| 国产欧美精品一区二区色综合 | 午夜国产不卡在线观看视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲黄色成人| 亚洲七七久久综合桃花剧情介绍| 亚洲激情综合| 亚洲最新在线视频| 午夜精品视频在线| 麻豆精品传媒视频| 亚洲另类自拍| 西西人体一区二区| 六月婷婷久久| 国产精品成人一区二区三区夜夜夜 | 亚洲乱码国产乱码精品精98午夜| 亚洲激情专区| 欧美一区二区三区四区高清 | 久久人人爽人人爽爽久久| 欧美大片18| 亚洲一区二区三区涩| 久久久999精品视频| 欧美精品电影| 韩国免费一区| 一区二区三区不卡视频在线观看 | 国产乱人伦精品一区二区| 激情成人中文字幕| 亚洲精品一区二区在线| 欧美一区二区精品久久911| 欧美成人国产一区二区| 亚洲性视频网址| 免费不卡视频| 午夜精品久久久久久久久| 亚洲精品一区二区三区在线观看 | 日韩一区二区电影网| 欧美一区二区三区免费看| 欧美a级在线| 亚洲欧美国产77777| 免费短视频成人日韩| 国产精品专区一| 亚洲毛片网站| 欧美国产高潮xxxx1819| 欧美在线视频a| 国产精品一卡二卡| 一本大道久久a久久精品综合| 男男成人高潮片免费网站| 亚洲欧美日韩一区二区| 欧美精品偷拍| 亚洲美洲欧洲综合国产一区| 麻豆freexxxx性91精品| 久久久久久高潮国产精品视| 国产一区自拍视频| 久久久99久久精品女同性| 亚洲一级影院| 国产精品久久久久久福利一牛影视| 亚洲激情电影中文字幕| 鲁大师成人一区二区三区 | 免费高清在线一区| 篠田优中文在线播放第一区| 国产精品扒开腿做爽爽爽视频| 亚洲美女av网站| 91久久亚洲| 午夜亚洲性色视频| 国产亚洲精品bv在线观看| 久久成人精品一区二区三区| 亚洲综合视频网| 国产日本精品| 久久一区精品| 美女尤物久久精品| 亚洲精品影院在线观看| 日韩一级二级三级| 国产精品久久久久久五月尺| 亚洲欧美日韩精品久久亚洲区 | 欧美在线啊v| 国产日韩欧美精品| 久久久精品免费视频| 久久国产精品毛片| 在线视频国产日韩| 亚洲国产精品99久久久久久久久| 欧美电影在线观看| 亚洲一区二区影院| 香蕉久久精品日日躁夜夜躁| 国产在线拍揄自揄视频不卡99 | 欧美a级片一区| 亚洲人成网站在线观看播放| 一区二区高清| 国产欧美一区二区白浆黑人| 久久久蜜桃精品| 欧美电影在线播放| 亚洲午夜视频在线| 欧美中文在线观看国产| 亚洲激情小视频| 亚洲特级毛片| 激情一区二区| 99re在线精品| 伊人精品视频| 99国产一区| 激情综合网址| 日韩视频在线播放| 尤物精品国产第一福利三区| 日韩视频一区二区三区在线播放| 国产精品午夜av在线| 欧美jjzz| 国产精品日韩精品| 亚洲国产一区二区三区a毛片| 国产精品欧美日韩久久| 免费日韩成人| 国产色产综合色产在线视频| 亚洲国产精品精华液网站| 国产精品视频xxxx| 亚洲国产日韩精品| 精品1区2区3区4区| 亚洲欧美一区二区原创| 在线视频你懂得一区二区三区| 久久精品日韩一区二区三区| 亚洲欧美国内爽妇网| 欧美国产日韩免费| 男女视频一区二区| 国产一区二区三区久久 | 久久国内精品自在自线400部| 另类天堂视频在线观看| 久久成人久久爱| 国产欧美日韩综合一区在线观看| 亚洲日本中文| 亚洲精品国产精品久久清纯直播 | 久久精品国语| 久久精品国产久精国产思思| 国产精品高清网站| av成人天堂| 亚洲一区视频在线| 欧美日韩调教| 正在播放欧美视频| 亚洲一区二区3| 欧美日韩国产大片| 亚洲精品欧美| 亚洲一区二区在线免费观看| 欧美午夜不卡在线观看免费 | 亚洲在线视频观看| 亚洲你懂的在线视频| 免费在线亚洲欧美| 国内自拍一区| 久久综合色88| 极品尤物av久久免费看| 欧美与黑人午夜性猛交久久久| 久久精品亚洲一区| 国产亚洲一区二区三区在线观看 | 久久精品亚洲精品国产欧美kt∨| 欧美性猛交xxxx乱大交蜜桃 | 亚洲最快最全在线视频| 99视频国产精品免费观看| 欧美极品一区二区三区| 亚洲欧洲午夜| 亚洲一品av免费观看| 国产精品国产a级| 亚洲免费视频在线观看| 久久国产视频网站| 亚洲福利视频专区| 欧美人与禽猛交乱配| 一区二区精品在线| 欧美一区高清| 亚洲高清av| 嫩草国产精品入口| 亚洲精品一区二区三区四区高清| 亚洲午夜成aⅴ人片| 国产精品素人视频| 久久久蜜臀国产一区二区| 亚洲福利视频在线| 亚洲一区二区在线| 精久久久久久| 欧美图区在线视频| 久久精精品视频| 亚洲精选中文字幕| 久久免费高清视频| 一区二区三区久久久| 国产一区二区三区久久久| 欧美激情a∨在线视频播放| 午夜精品视频一区| 欧美韩日视频| 久久精品成人一区二区三区| 亚洲欧洲精品一区二区精品久久久 | 99视频一区二区三区| 国产精品乱码久久久久久| 久久另类ts人妖一区二区| 99成人精品| 欧美激情在线狂野欧美精品| 欧美一区二区三区四区在线观看 | 久久精品在这里| 一区二区三区高清不卡| 欧美大片免费| 久久精品综合网| 亚洲综合色自拍一区| 91久久精品久久国产性色也91| 国产精品一区在线观看你懂的| 欧美凹凸一区二区三区视频| 欧美亚洲免费电影| 亚洲香蕉视频| 99成人在线| 日韩视频一区二区三区在线播放免费观看| 久久一区二区精品| 久久九九免费视频|