error LNK2005

  今天一大早,VC就給我來了個下馬威,昨天還老老實實工作着的程序,竟然出現58個錯誤,而且還都是類似的LNK2005!滿滿的一屏error,這對於初爲程序員的我,那簡直是致命的,心靈受的打擊啊~~~

    趕緊Google,發現各位程友們也被這困擾着,不過還是有高手支招的,以下摘錄:

 

    編程中經常能遇到LNK2005錯誤——重複定義錯誤,其實LNK2005錯誤並不是一個很難解決的錯誤。弄清楚它形成的原因,就可以輕鬆解決它了。   
    造成LNK2005錯誤主要有以下幾種情況:  
    1.重複定義全局變量。可能存在兩種情況:  
    A、對於一些初學編程的程序員,有時候會以爲需要使用全局變量的地方就可以使用定義申明一下。其實這是錯誤的,全局變量是針對整個工程的。正確的應該是在一個CPP文件中定義如下:int   g_Test;那麼在使用的CPP文件中就應該使用:extern   int   g_Test即可,如果還是使用int   g_Test,那麼就會產生LNK2005錯誤,一般錯誤錯誤信息類似:AAA.obj   error   LNK2005   int   book   c?book@@3HA   already   defined   in   BBB.obj。切記的就是不能給變量賦值否則還是會有LNK2005錯誤。

這裏需要的是“聲明”,不是“定義”!根據C++標準的規定,一個變量是聲明,必須同時滿足兩個條件,否則就是定義:  
  (1)聲明必須使用extern關鍵字;(2)不能給變量賦初值  
  所以,下面的是聲明:  
  extern   int   a;  
  下面的是定義  
  int a; int a = 0; extern int a =0;  
  B、對於那麼編程不是那麼嚴謹的程序員,總是在需要使用變量的文件中隨意定義一個全局變量,並且對於變量名也不予考慮,這也往往容易造成變量名重複,而造成LNK2005錯誤。  
   
    2.頭文件的包含重複。往往需要包含的頭文件中含有變量、函數、類的定義,在其它使用的地方又不得不多次包含之,如果頭文件中沒有相關的宏等防止重複鏈接的措施,那麼就會產生LNK2005錯誤。解決辦法是在需要包含的頭文件中做類似的處理:

  #ifndef MY_H_FILE       //如果沒有定義這個宏  
  #define MY_H_FILE       //定義這個宏  
  …….       //頭文件主體內容  
  …….  
  #endif  
  上面是使用宏來做的,也可以使用預編譯來做,在頭文件中加入:  
  #pragma once  
  //頭文件主體

  
    3.使用第三方庫造成的。這種情況主要是C運行期函數庫和MFC的庫衝突造成的。具體的辦法就是將那個提示出錯的庫放到另外一個庫的前面。另外選擇不同的 C函數庫,可能會引起這個錯誤。微軟和C有兩種C運行期函數庫,一種是普通的函數庫:LIBC.LIB,不支持多線程。另外一種是支持多線程 的:msvcrt.lib。如果一個工程裏,這兩種函數庫混合使用,可能會引起這個錯誤,一般情況下它需要MFC的庫先於C運行期函數庫被鏈接,因此建議 使用支持多線程的msvcrt.lib。所以在使用第三方的庫之前首先要知道它鏈接的是什麼庫,否則就可能造成LNK2005錯誤。如果不得不使用第三方 的庫,可以嘗試按下面所說的方法修改,但不能保證一定能解決問題,前兩種方法是微軟提供的:  
  A、選擇VC菜單Project->Settings->Link->Catagory選擇Input,再在Ignore   libraries   的Edit欄中填入你需要忽略的庫,如:Nafxcwd.lib;Libcmtd.lib。然後在Object/library   Modules的Edit欄中填入正確的庫的順序,這裏需要你能確定什麼是正確的順序。   
  B、選擇VC菜單Project->Settings->Link頁,然後在Project   Options的Edit欄中輸入/verbose:lib,這樣就可以在編譯鏈接程序過程中在輸出窗口看到鏈接的順序了。  
  C、選擇VC菜單Project->Settings->C/C++頁,Catagory選擇Code Generation後再在User Runtime Libraray中選擇MultiThread DLL等其他庫,逐一嘗試。  
    關於編譯器的相關處理過程,參考:  
    http://www.donews.net/xzwenlan/archive/2004/12/23/211668.aspx  
   
    這就是我所遇到過的LNK2005錯誤的幾種情況,肯定還有其他的情況也可能造成這種錯誤,所以我不希望你在看完這篇文章以後,再遇到LNK2005錯誤時候,不動腦筋的想對號入座的排除錯誤。編程的過程就是一個思考的過程,所以還是多多開動你的頭腦,那樣收穫會更多!

    針對我的程序,使用的是boost第三方庫,正則表達式嵌入後,也許像高手所說的那樣,重複定義了,多個目標文件不能重複定義同名的函數與初始化了的全局變量,可鏈接時,我是按照VS2005的步驟加入boost的啊,暈~~~

    1. 項目屬性頁-> C/C++ /常規/附加包含目錄/C:/Program Files/boost/boost_1_36_0

    2. 項目屬性頁-> 鏈接器/常規/附加庫目錄/C:/Program Files/boost/boost_1_36_0/libs

今天是週五,老總剛從上海飛回來,說不定一會兒就檢查我的代碼了,我的媽呀——

於是死馬當作活馬醫,試驗各種網上的辦法,都不行

    最後改了上述的第2.爲:

    項目屬性頁-> 鏈接器/常規/附加庫目錄/D:/Program Files/Microsoft Visual Studio 8/VC/lib

竟然無錯誤了、正常運行了!!!

難道是VC庫和boost的lib庫重複定義了?還是不敢肯定,不過終於解決了,成功——向優秀程序又跨了一步,耶

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章