日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
漫談C++代碼編寫

本文主要進行對C++代碼進行學(xué)習(xí)與說明,一旦掌握了一些編程的技巧和方式,在繁瑣和復(fù)雜的代碼也不會難倒一些學(xué)者和專門從事開發(fā)的技術(shù)人員,好了下面進行代碼舉例說明。

成都創(chuàng)新互聯(lián)2013年開創(chuàng)至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè)網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元瓊海做網(wǎng)站,已為上家服務(wù),為瓊海各地企業(yè)和個人服務(wù),聯(lián)系電話:028-86922220

C++代碼如下:

 
 
 
  1. //log.h  
  2.  
  3. #ifndef _LOG_H_  
  4. #define _LOG_H_  
  5. /*  
  6. LOG Library(WIN98/NT/2000) ver 0.1  
  7.  
  8. Compile by: BC++ 5; C++ BUILDER 4, 5, 6, X; VC++ 5, 6; VC.NET;  GCC;  
  9.     
  10. Copyright(c) 2006.5 - 2007.4  llbird wushaojian@21cn.com http://blog.csdn.net/wujian53  
  11.  
  12. Use:  
  13. 這是一個很簡單的日志, 用的是C風(fēng)格的函數(shù),支持多線程  
  14. 只要包含本文件,并且把log.cpp文件添加到項目中就可以了  
  15. 在VC中你可能需要在log.cpp中添加#include "stdafx.h"  
  16. 具體使用  
  17.  InitLog();//初始化  
  18.  LOG("程序啟動");  
  19.  LOG1("%s", str);  
  20.  DestroyLog();//可有可無  
  21.  
  22. 調(diào)試時輸出可以定義 LOG_TO_STD 或者 LOG_TO_DEBUG  
  23. 對于C++ Builder  
  24. 可以使用  
  25. LOG(Exception *e or Exception &e);  
  26. 對于WIN32 API  
  27. LOG_LAST_ERROR();  
  28. 對于_com_error  
  29. LOG( _com_error &e);  
  30. */  
  31.  
  32. #include  
  33. #include  
  34. #include  
  35. #include  
  36. //使用短的原文件名  
  37. #define LOG_SHORT_SOURCE_FILE  
  38. //使用日志  
  39. #define LOG_TO_FILE  
  40. //定義標(biāo)準(zhǔn)錯誤輸出設(shè)備  
  41. #define LOG_STD_DEV stderr  
  42. //使用標(biāo)準(zhǔn)輸出設(shè)備  
  43. //#define LOG_TO_STD  
  44. //向調(diào)試窗口輸出  
  45. //#define LOG_TO_DEBUG  
  46. //輸出messagebox  
  47. //#define LOG_TO_MESSAGE_BOX  
  48. //多線程用臨界區(qū)  
  49. extern CRITICAL_SECTION _g_LogMutex;  
  50. //全局日志文件名  
  51. extern char _g_LogFileName[MAX_PATH];  
  52. extern void InitLog(); //>初始化日志  
  53. extern void DestroyLog();//>清除日志  
  54. extern BOOL Log(const char* src/*源程序名*/, int line/*行號*/, const char* description/*描述*/);//>新增日志  
  55.  //記錄日志宏列表  
  56. #define LOG(arg) Log(__FILE__, __LINE__, (arg))  
  57. //多參數(shù)記錄日志宏  
  58. #define LOG1(str, p1) { LOG_SPRINTF_BUFFER; sprintf(buffer, (str), (p1)); LOG(buffer); }  
  59. #define LOG2(str, p1, p2) {LOG_SPRINTF_BUFFER; sprintf(buffer, (str), (p1), (p2)); LOG(buffer); }  
  60. #define LOG3(str, p1, p2, p3) { LOG_SPRINTF_BUFFER; sprintf(buffer, (str), (p1), (p2), (p3)); LOG(buffer); }  
  61. #define LOG4(str, p1, p2, p3, p4) { LOG_SPRINTF_BUFFER; sprintf(buffer, (str), (p1), (p2), (p3), (p4));LOG(buffer);}  
  62. #define LOG5(str, p1, p2, p3, p4, p5) { LOG_SPRINTF_BUFFER; sprintf(buffer, (str), (p1), (p2), (p3), (p4), (p5)); LOG(buffer);}  
  63. //記錄windows API錯誤值  
  64. #define LOG_LAST_ERROR() { LOG_SPRINTF_BUFFER; DWORD eid = GetLastError();sprintf(buffer, "Last Error(%d):", eid); int len = strlen(buffer);     \  
  65.  FormatMessage(       \  
  66.   FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,\  
  67.   NULL,\  
  68.   eid,  \  
  69.   MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), \  
  70.   buffer + len,\  
  71.   DEFAULT_LOG_SPRINTF_BUFFER_SIZE-len-1, \  
  72.   NULL \  
  73.   ); \  
  74.   LOG(buffer); \  
  75.   }\  
  76.  
  77. #if defined(__cplusplus) && defined(_INC_COMDEF)  
  78. ///新增COM錯誤信息  
  79. inline BOOL Log(const char* src, int line, _com_error &e)  
  80. {  
  81.  char buffer[DEFAULT_LOG_SPRINTF_BUFFER_SIZE];  
  82.  sprintf(buffer, "_com_error\tCode = %x\tCode meaning = %s\tSource = %s\tDescription = %s",   
  83.   e.Error(), (LPCSTR)(_bstr_t)e.ErrorMessage(), (LPCSTR)(_bstr_t)e.Source(), (LPCSTR)(_bstr_t)e.Description());  
  84.  return LOG_POS(src, line, buffer);  
  85. }  
  86. #endif  
  87.  
  88. ///新增VCL異常信息  
  89. #if defined(__cplusplus) && defined(__BORLANDC__) && defined(INC_VCL)  
  90. inline BOOL Log(const char* src, int line, Exception *e)  
  91. {  
  92.  return LOG_POS(src, line, e->Message.c_str());  
  93. }  
  94. inline BOOL Log(const char* src, int line, Exception &e)  
  95. {  
  96.  return LOG_POS(src, line, e.Message.c_str());  
  97. }  
  98. #endif  
  99.  
  100. #endif _LOG_H_  

看了以上那么多的C++代碼我相信大家已經(jīng)有點迷糊了吧,那就好好消化一下吧。


網(wǎng)站名稱:漫談C++代碼編寫
分享網(wǎng)址:http://www.dlmjj.cn/article/coiccpj.html