介绍一个专门处理C++异常的类
2010-01-23 20:32:25 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鎯у⒔閹虫捇鈥旈崘顏佸亾閿濆簼绨绘い鎺嬪灪閵囧嫰骞囬姣挎捇鏌熸笟鍨妞ゎ偅绮撳畷鍗炍旈埀顒勭嵁婵犲嫮纾介柛灞捐壘閳ь剛鎳撻~婵嬪Ω閳轰胶鐤呯紓浣割儐椤戞瑩宕ョ€n喗鐓曟い鎰靛亝缁舵氨绱撻崘鈺傜婵﹤顭峰畷鎺戔枎閹搭厽袦婵犵數濮崑鎾绘⒑椤掆偓缁夌敻骞嗛悙鍝勭婵烇綆鍓欐俊鑲╃磼閹邦収娈滈柡灞糕偓鎰佸悑閹肩补鈧尙鏁栧┑鐐村灦閹稿摜绮旈悽绋课﹂柛鏇ㄥ灠閸愨偓濡炪倖鍔﹀鈧繛宀婁邯濮婅櫣绱掑Ο璇茶敿闂佺ǹ娴烽弫璇差嚕婵犳碍鏅插璺猴工瀹撳棝姊虹紒妯哄缂佷焦鎸冲畷鎴﹀箻鐠囧弶宓嶅銈嗘尰缁嬫垶绂嶉悙顒佸弿婵☆垳鍘ф禍楣冩倵濮樼偓瀚�

为了在release模式中给代码提供符号,必须按照下列步骤修改工程设置:
1.Project Settings -> Link -> Debug (Category) , 启用“Debug Info” 并选中“Microsoft Format”。
2.相同的地方,选中“Separate Types”。
3.在相同页的“Project Options”编辑框中,添加“/OPT:REF”,这样可以保证从最终的二进制中排除掉未引用的函数。
4.Project Settings -> C++ -> General (Category) Debug Info 组合框 -> 选择“Program Database”
5.如果要对无意义的堆栈进行调用,那么需将“Optimizations”设置为“Disable (Debug)”。
还要记住与代码一起分发最终生成的pdb文件(或用其它方法使之可以得到)。以便CExceptionLogger能在最终的日志中给出源和行信息。
请注意由于所有的符号,即便是很小的应用的符号,各自的异常日志可能超过100K。我的观点是磁盘空间不值钱,而开发人员为查找BUG所花的时间则很宝贵。
参考资料:Bugslayer, MSJ, August 1998 by John Robbins,
http://www.microsoft.com/msj/defaultframe.asp?page=/msj/0898/bugslayer0898.htm
Under the Hood, MSDN, March 2002 by Matt Pietrek,
http://msdn.microsoft.com/msdnmag/issues/02/03/Hood/Hood0203.asp
改进计划:
可配置日志文件名。
提供对Win64平台的支持。
提供对非x86 调用堆栈的支持。
如果有任何改进建议,不妨来信告知,以便我将它们加到下下一个版本中。
本文配套源码
更多精彩
赞助商链接