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

阿攀的博客

海闊天空

  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  5 隨筆 :: 2 文章 :: 11 評(píng)論 :: 0 Trackbacks
     最近接受一個(gè)項(xiàng)目,因環(huán)境受限,無法進(jìn)行對(duì)其代碼調(diào)試。發(fā)生問題時(shí),只能通過log內(nèi)容分析原因。由于無法調(diào)試,函數(shù)間的調(diào)用關(guān)系只能通過查看源代碼得知,比較痛苦。由于源代碼中每個(gè)函數(shù)都增加了log,遂萌發(fā)通過log自動(dòng)分析函數(shù)間的調(diào)用關(guān)系,現(xiàn)已實(shí)現(xiàn),和感興趣的朋友分享下,但愿對(duì)其有幫助。
    記錄log的內(nèi)容是:
   
 1 class CPLog
 2 {
 3 public:
 4     CPLog(char *szFileName, char *szFunctionName, UINT32 uLine)
 5     {
 6         m_pFileName = szFileName;
 7         m_pFunctionName = szFunctionName;
 8         static long nID = 1;
 9 
10         m_nid = InterlockedIncrement(&nID);
11 
12         //write_log就不實(shí)現(xiàn)了,把這行日志寫到文件中
13         write_log(( "ThreadID:%d +[S:%d]EnterFunc:%s +Line:%d"
14                      GetCurrentThreadId(), 
15                      m_nid,
16                      m_pFunctionName,
17                      uLine));
18     }
19     ~CPLog()
20     {
21         write_log(( "ThreadID:%d +[E:%d]LeaveFunc:%s "
22                      GetCurrentThreadId(), 
23                      m_nid,
24                      m_pFunctionName)));
25     }
26 private:
27     char *m_pFileName;
28     char *m_pFunctionName;
29     long m_nid;
30 };
31 
32 #define CP_LOG_FUNCTION(filename, funcname, lines)  \
33     CPLog mylogFunctionName(filename, funcname, lines)
    然后在每個(gè)函數(shù)入口的地方加上這句:
  
CP_LOG_FUNCTION(__FILE__, __FUNCTION__, __LINE__);
   最后,把log文件通過這個(gè)python腳本文件(在這里不講解了,自己看源代碼吧)分析,即可
     funcstack.rar
  效果是這樣的:(看法,從左到右,從上到下,如果存在函數(shù)調(diào)用沒有結(jié)束也會(huì)有信息輸出)
main---->CShell::onInitCompleted---->CShell::stopInitializationWorker---->CShellAsyncTask::~CShellAsyncTask
                                            
---->CShell::writeUnitIdToHdd---->CShell::getHDDPath
                                                                                     
---->CAppManager::writeUnitIdToSdCard---->get_os_version
                                                                                                                                             
---->GetFileVersion
                                                                                                                                            
---->CShell::ShellIniSettings
*****************************************
There are 2 function not end and function stack is:
CShell::onInitCompleted, line:159
main, line:23
*****************************************


   
 注:轉(zhuǎn)發(fā)請(qǐng)注明來源,謝謝!
 微博:http://weibo.com/caipan1984

posted on 2011-11-12 21:10 阿攀 閱讀(2539) 評(píng)論(2)  編輯 收藏 引用

評(píng)論

# re: 根據(jù)日志內(nèi)容分析函數(shù)調(diào)用堆棧(function stack) 2011-11-12 21:49 huzfei
頂,記日志的流行做法!  回復(fù)  更多評(píng)論
  

# re: 根據(jù)日志內(nèi)容分析函數(shù)調(diào)用堆棧(function stack) 2011-11-13 10:40 阿攀
@huzfei
Thank you to support!  回復(fù)  更多評(píng)論
  


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品视频yy9099| 久久精品女人的天堂av| 欧美va亚洲va国产综合| 亚洲电影毛片| 亚洲大片一区二区三区| 免费观看久久久4p| 日韩午夜中文字幕| 正在播放亚洲| 国产啪精品视频| 久久综合网hezyo| 免费观看日韩| 亚洲永久精品国产| 久久成人精品视频| 亚洲国产专区校园欧美| 亚洲精品在线一区二区| 国产精品久久久久久久久久免费| 午夜精品久久久久久久久久久久久| 亚洲午夜影视影院在线观看| 国语自产精品视频在线看抢先版结局| 麻豆91精品91久久久的内涵| 欧美黄色小视频| 欧美一区二区三区在线观看视频 | 亚洲影院色无极综合| 亚洲天堂av图片| 黄色一区二区在线| 亚洲国内精品| 国产免费亚洲高清| 欧美激情自拍| 国产精品资源| 亚洲激情电影在线| 国产亚洲一区二区在线观看 | 亚洲主播在线| 久久久视频精品| 亚洲午夜在线视频| 久久乐国产精品| 亚洲视频免费观看| 久久视频在线免费观看| 亚洲欧美日本精品| 乱码第一页成人| 久久本道综合色狠狠五月| 欧美成黄导航| 久久久蜜桃一区二区人| 欧美日韩国产专区| 欧美高清hd18日本| 国产午夜精品久久久久久免费视 | 亚洲欧美日韩人成在线播放| 欧美成人资源| 猛男gaygay欧美视频| 国产精品日韩欧美| 亚洲精品日本| 亚洲日本免费| 久久三级视频| 国产精品v欧美精品∨日韩| 亚洲精品乱码久久久久| 欧美与欧洲交xxxx免费观看 | 国产区精品在线观看| 亚洲免费黄色| 亚洲精品在线观看视频| 老司机精品视频一区二区三区| 欧美一区二区在线播放| 国产精品啊v在线| 99国产精品久久久久久久久久| 在线日韩av永久免费观看| 欧美在线播放视频| 久久精品国产亚洲一区二区| 国产精品欧美久久| 亚洲天堂成人| 先锋影音网一区二区| 国产精品久久久久一区二区三区共| 亚洲日本黄色| 中文成人激情娱乐网| 欧美日韩亚洲一区三区 | 欧美成人午夜影院| 亚洲盗摄视频| 久久综合精品国产一区二区三区| 免费在线亚洲欧美| 亚洲高清二区| 欧美精品免费观看二区| 日韩视频精品在线| 亚洲与欧洲av电影| 国产日韩av高清| 久久激情综合| 欧美国产日本在线| 亚洲最新在线视频| 国产精品av一区二区| 亚洲字幕一区二区| 久久露脸国产精品| 最新亚洲激情| 欧美丝袜一区二区三区| 性色一区二区三区| 欧美粗暴jizz性欧美20| 99精品久久久| 国产精品一区二区欧美| 久久国产综合精品| 亚洲国产二区| 亚洲欧美日韩中文在线制服| 国产欧美精品va在线观看| 久久久噜噜噜久久| 亚洲精品中文在线| 久久久av毛片精品| 日韩亚洲欧美综合| 国产欧美日韩亚洲精品| 久久久夜夜夜| 日韩视频三区| 久久男人av资源网站| 日韩视频在线免费观看| 国产乱理伦片在线观看夜一区| 久久人人精品| 亚洲天堂久久| 亚洲电影在线看| 欧美一级久久久| 亚洲精品免费看| 国产亚洲欧美一区| 欧美视频在线观看 亚洲欧| 久久精彩免费视频| 99热在这里有精品免费| 美女主播一区| 翔田千里一区二区| 在线亚洲一区二区| 久久久美女艺术照精彩视频福利播放| 久久综合九色综合久99| 亚洲专区免费| 亚洲国产综合在线| 老司机午夜精品| 亚洲欧美一区二区三区在线| 91久久精品日日躁夜夜躁欧美| 国产精品日韩高清| 欧美日韩精品久久久| 免费亚洲一区| 久久久国产一区二区三区| 国产精品99久久久久久白浆小说| 亚洲成色999久久网站| 久久久久久久性| 欧美一区二区三区视频| 亚洲图片你懂的| 亚洲美女淫视频| 亚洲激情视频网站| 狠狠干综合网| 国产亚洲一本大道中文在线| 国产欧美亚洲一区| 国产精品日韩一区二区三区| 国产精品精品视频| 欧美性猛片xxxx免费看久爱 | 亚洲欧美韩国| 亚洲午夜免费福利视频| 一区二区高清视频在线观看| 99国产精品久久久久久久| 亚洲精选在线| 夜夜嗨av一区二区三区四季av| 亚洲精品在线观看视频| 亚洲狼人精品一区二区三区| 亚洲激情婷婷| 亚洲欧洲日本国产| 亚洲卡通欧美制服中文| 日韩亚洲综合在线| 中文网丁香综合网| 午夜国产精品视频| 久久成人资源| 快播亚洲色图| 欧美激情在线| 国产精品国产成人国产三级| 国产精品久久久久秋霞鲁丝| 国产欧美一区二区精品性色| 国产手机视频一区二区| 伊人成年综合电影网| 亚洲欧洲日夜超级视频| 一区二区三区视频在线观看 | 在线免费不卡视频| 亚洲伦理在线| 亚洲免费视频中文字幕| 久久久久久久久久久久久女国产乱| 久久一区二区三区四区五区| 亚洲电影免费观看高清完整版在线观看| 欧美岛国激情| 99re66热这里只有精品4| 亚洲欧美日韩中文视频| 久久视频国产精品免费视频在线| 欧美激情日韩| 国产精品一区二区三区观看 | 欧美黄色影院| 国产精品一区二区女厕厕| 亚洲高清成人| 午夜精品美女久久久久av福利| 久久亚洲综合色| 亚洲美女诱惑| 欧美一区日韩一区| 欧美日本成人| 国产综合av| 亚洲色图在线视频| 欧美电影免费观看高清完整版| 99精品99久久久久久宅男| 欧美在线播放一区二区| 欧美午夜激情视频| 亚洲品质自拍| 久久国产精品久久久久久| 亚洲人成亚洲人成在线观看| 亚洲男人的天堂在线| 久久黄色网页| 99国产精品久久久久久久成人热| 久久夜色精品国产欧美乱|