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

asm, c, c++ are my all
-- Core In Computer
posts - 139,  comments - 123,  trackbacks - 0

/********************************************\
|????歡迎轉載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!???? |
\********************************************/

VC++的鏈接錯誤LNK2005


作者: Jerry Cat
時間: 2006/04/19
鏈接: http://m.shnenglu.com/jerysun0818/archive/2006/04/19/5913.html

編程中經常能遇到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欄中填入正確的庫的順序,這里需要你能確定什么是正確的順序,呵呵,God bless you!
B、選擇VC菜單Project->Settings->Link頁,然后在Project Options的Edit欄中輸入/verbose:lib,這樣就可以在編譯鏈接程序過程中在輸出窗口看到鏈接的順序了。
C、選擇VC菜單Project->Settings->C/C++頁,Catagory選擇Code Generation后再在User Runtime libraray中選擇MultiThread DLL等其他庫,逐一嘗試。

這就是我所遇到過的LNK2005錯誤的幾種情況,肯定還有其他的情況也可能造成這種錯誤,所以我不希望你在看完這篇文章以后,再遇到LNK2005錯誤時候,不動腦筋的想對號入座的排除錯誤。編程的過程就是一個思考的過程,所以還是多多開動你的頭腦,那樣收獲會更多!
=======================================
支持,我在社區里也看到了許多LINK 2005錯
補充一點,就是一次在用第三方庫時,由于errno被重定義,用多種方法都不能解決,后查找MSDN,發現link有個選項/FORCE可以解決,在IDE下
Project->Settings->Link頁,選categroy為custom,將force file output前打勾
但會有警告
warning LNK4088: image being generated due to /FORCE option; image may not run
但的確解決了問題,這是由于VC對重定義比較嚴格,像BCB或GCC在庫中的重定義不會有任何警告或錯誤
========================================
我發現的另外一個出現LINK2005的現象,好像是由于名稱空間而引起的。我在dos下寫的程序沒有問題,但是放在mfc中就出現了這個鏈接錯誤。因為起初圖省事,我在一個頭文件中寫了using namespace std,并且這個頭文件我多處使用,另外,我還使用了boost庫。后來,問題解決的方法非常奇怪,在一個頭文件中引用其他頭文件,這些頭文件的順序換一下就通過了,那個出現問題的頭文件中我使用了std::map,當我把這種容器使用模板代替后,鏈接就有沒事了。(例如:template<class coll>),后來感到模板技術還有這種效果,賺了!哈哈
========================================
What are the C and C++ libraries my program would link with?

????????????????????? Summary Table

?Compile?? Old???????????? New IOStream?? ?Libraries

?Option???? IOStream?? ?or STL???????? ?????? Linked With

?

?/ML??????? No??????????????? No???????????????????LIBC.LIB

?/MLd????? No??????????????? No???????????????????LIBCD.LIB

?/MT??????? No??????????????? No???????????????????LIBCMT.LIB

?/MTd????? No??????????????? No???????????????????LIBCMTD.LIB

?/MD?????? No???????????????? No???????????????????MSVCRT.LIB

?/MDd?????No???????????????? No???????????????????MSVCRTD.LIB

?/ML??????? No??????????????? Yes???????????????????LIBC.LIB,??? ?LIBCP.LIB

?/MLd????? No??????????????? Yes???????????????????LIBCD.LIB,?? LIBCPD.LIB

?/MT??????? No??????????????? Yes???????????????????LIBCMT.LIB,? LIBCPMT.LIB

?/MTd????? No??????????????? Yes???????????????????LIBCMTD.LIB, LIBCPMTD.LIB

?/MD??????? No??????????????? Yes???????????????????MSVCRT.LIB,? MSVCPRT.LIB

?/MDd????? No??????????????? Yes???????????????????MSVCRTD.LIB, MSVCPRTD.LIB

?/ML??????? Yes??????????????? No???????????????????LIBC.LIB,??? ??LIBCI.LIB

?/MLd????? Yes??????????????? No???????????????????LIBCD.LIB,?? ?LIBCID.LIB

?/MT??????? Yes??????????????? No???????????????????LIBCMT.LIB,? ?LIBCIMT.LIB

?/MTd????? Yes??????????????? No???????????????????LIBCMTD.LIB, ?LIBCIMTD.LIB

?/MD??????? Yes??????? ?????? No???????????????????MSVCRT.LIB,? MSVCIRT.LIB

?/MDd????? Yes??????? ?????? No???????????????????MSVCRTD.LIB, MSVCIRTD.LIB


你的程序使用了/ML編譯選項,而程序依賴的.lib可能使用/MDd選項編譯,造成鏈接沖突.

統一編譯選項可回避此錯誤
Project Settings->C/C++ Tab->Category:CodeGeneration
Use run-time library組合框中選擇Multithread Dll(或Debug Multithread Dll )

Summary Table for CRT DLLs Used
Import Library Linked With DLLs Used (Visual C++ 5.0|6.0) DLLs Used (Visual C++ 4.2) DLLs Used (Visual C++ .NET 2002| Visual C++ .NET 2003)
MSVCRT.LIB MSVCRT.DLL MSVCRT.DLL MSVCRT.DLL
MSVCRTD.LIB MSVCRTD.DLL MSVCRTD.DLL MSVCRTD.DLL
MSVCPRT.LIB MSVCP(5|6)0.DLL MSVCP7(0|1).DLL
MSVCPRTD.LIB MSVCP(5|6)0D.DLL MSVCP7(0|1)D.DLL
MSVCIRT.LIB MSVCIRT.DLL MSVCIRT.DLL
MSVCIRTD.LIB MSVCIRTD.DLL MSVCIRTD.DLL


注意:所有相關工程都應該選擇相同編譯選項
========================================
微軟的MSDN中查到信息的

可能的原因

不慎同時與單線程庫和多線程庫鏈接。確保應用程序項目文件只包括適當的庫,并且任何第三方庫已適當創建了單線程或多線程版本。
該符號為封裝函數(通過用 /Gy 編譯創建),包含在多個文件中,但在各編譯間已改變。重新編譯所有包含 symbol 的文件。
以不同的形式在不同庫中的兩個成員對象中定義了該符號,并且使用了這兩個成員對象。
某個絕對符號被定義兩次,而每次定義的值不同。
頭文件聲明并定義了變量。可能的解決方案有:
在 .h 中聲明變量:extern BOOL MyBool;,然后在 .c 或 .cpp 文件中向它分配:BOOL MyBool = FALSE;。
將變量聲明為 Static。
將變量聲明為 selectany。
當將 uuid.lib 與定義 GUID 的其他 .lib 文件(例如 oledb.lib 和 adsiid.lib)一起使用時。例如:
oledb.lib(oledb_i.obj) : error LNK2005: _IID_ITransactionObject
already defined in uuid.lib(go7.obj)
若要修復,請將 /FORCE:MULTIPLE 添加到鏈接器命令行選項,并確保 uuid.lib 是引用的第一個庫。

有關更多信息,請參閱知識庫文章:

Q148652,PRB: LNK2005 Errors When Link C Run-Time Libraries Are Linked Before MFC Libraries。
Q140440,FIX: Global Overloaded Delete Operator Causes LNK2005。
Q184235,PRB: LNK2005 Errors on New and Delete When Defining _ATL_MIN_CRT。
該錯誤之后為致命錯誤 LNK1169。
=======================================
有時候因為工程使用了預編譯頭文件并且是增量編譯,所以當你改動以后可能也會出現LNK2005錯誤,提示“XXXX已經在XXXX.obj文件中定義”的消息,這時候只要Rebuild All一般都能解決問題。這是因為頭文件的順序被改動等等操作造成的。
最后要說明的:事物是在不斷變化中的,C++的標準在變化,編譯器也在變化,所以并不是所有的LNK2005錯誤都可以在這里找到答案,但是至少它能給你以提示。學習并思考才是正確的!

posted on 2006-04-19 23:45 Jerry Cat 閱讀(3941) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理



<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(7)

隨筆檔案

最新隨筆

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久国产精品一区二区| 裸体一区二区三区| 亚洲黄色一区| 久久这里有精品视频| 在线亚洲伦理| 欧美岛国在线观看| 在线观看免费视频综合| 欧美在线免费看| 亚洲一区制服诱惑| 欧美日韩亚洲不卡| 一区二区动漫| 亚洲精品亚洲人成人网| 午夜在线不卡| 国产欧美精品日韩| 欧美一区二区三区播放老司机| 亚洲国产精品一区制服丝袜| 亚洲伊人伊色伊影伊综合网| 欧美调教视频| 亚洲免费在线电影| 亚洲一区二区视频| 国产日本欧美一区二区| 欧美综合第一页| 欧美一区二区啪啪| 精品福利av| 欧美激情影院| 欧美日韩色一区| 亚洲欧美www| 午夜久久久久| 激情综合中文娱乐网| 乱码第一页成人| 欧美大片免费久久精品三p| 99re6这里只有精品| 一区二区不卡在线视频 午夜欧美不卡在| 欧美日韩成人一区| 午夜精彩国产免费不卡不顿大片| 亚洲综合三区| 在线观看欧美| 日韩视频不卡中文| 国产自产女人91一区在线观看| 免费观看在线综合色| 欧美国产亚洲另类动漫| 亚洲一区区二区| 欧美专区福利在线| 日韩视频精品在线观看| 亚洲最新在线视频| 国内精品美女av在线播放| 欧美r片在线| 欧美日韩亚洲综合在线| 久久精品99国产精品| 免费亚洲电影在线| 亚洲欧美日韩精品久久亚洲区| 久久99伊人| av成人手机在线| 久久成人18免费网站| 亚洲日本视频| 午夜精品免费| av不卡免费看| 久久爱另类一区二区小说| 亚洲免费观看高清在线观看 | 久久全球大尺度高清视频| 美女亚洲精品| 欧美专区在线观看一区| 欧美精品v日韩精品v韩国精品v | 亚洲欧美视频| 亚洲精品在线视频| 久久国产加勒比精品无码| 99ri日韩精品视频| 久久久久久久网站| 午夜精品视频在线| 欧美xxx在线观看| 性xx色xx综合久久久xx| 久久久久久一区二区三区| 中文在线资源观看网站视频免费不卡| 欧美一区2区三区4区公司二百| 亚洲另类春色国产| 久久精品123| 欧美专区18| 欧美午夜电影完整版| 欧美大片免费久久精品三p | 久久精品30| 欧美手机在线| 亚洲国产精品精华液2区45| 国产精品久久久久久久久借妻| 亚洲精品视频一区二区三区| 在线免费观看日本一区| 欧美在线欧美在线| 久久久久国产精品一区| 国产精品一区二区男女羞羞无遮挡 | 欧美专区18| 欧美日韩调教| 欧美国产一区视频在线观看| 国产一区二区高清| 亚洲综合另类| 羞羞漫画18久久大片| 欧美日韩在线视频一区| 亚洲三级免费| 亚洲精品午夜精品| 欧美成人精品在线视频| 亚洲电影第1页| 亚洲第一精品久久忘忧草社区| 午夜性色一区二区三区免费视频| 午夜欧美电影在线观看| 国产精品五区| 亚洲在线第一页| 久久av红桃一区二区小说| 国产欧美一区二区精品仙草咪| 午夜天堂精品久久久久| 久久永久免费| 91久久综合亚洲鲁鲁五月天| 免费观看日韩| 日韩亚洲成人av在线| 亚洲一区二区三区777| 欧美视频一区在线观看| 亚洲一区不卡| 久久精品九九| 伊人狠狠色丁香综合尤物| 乱人伦精品视频在线观看| 亚洲国产成人久久综合一区| 中文国产亚洲喷潮| 国产欧美在线播放| 久久精品一区二区三区不卡| 欧美69wwwcom| 99在线观看免费视频精品观看| 欧美午夜无遮挡| 欧美在线播放一区二区| 国产精品成人观看视频免费| 久久综合色播五月| 99视频精品在线| 欧美日韩精品一本二本三本| 国产日韩欧美制服另类| 欧美国产1区2区| 国产精品国产亚洲精品看不卡15 | 久久国产精品久久精品国产| 欧美激情按摩在线| 欧美成人国产一区二区| 国产一区二区三区在线观看精品 | 欧美影院在线播放| 欧美视频一区二区三区四区 | 久久er精品视频| 亚洲一区二区在线看| 欧美日韩免费观看一区三区 | 亚洲韩日在线| 国产精品色午夜在线观看| 一本色道久久综合亚洲精品不| 一二美女精品欧洲| 欧美人成在线视频| 日韩视频中午一区| 亚洲影院免费| 国产精品一区二区在线| 亚洲一级在线观看| 午夜精品成人在线视频| 国产精品尤物| 亚洲欧美日韩精品久久久久| 欧美一区二区三区四区在线观看地址| 欧美日韩综合在线免费观看| 亚洲国产mv| 一区二区三欧美| 国产精品久久久久77777| 亚洲在线黄色| 久久久之久亚州精品露出| 亚洲大胆女人| 欧美精品入口| 中文在线一区| 久久久久天天天天| 国产有码一区二区| 麻豆freexxxx性91精品| 美国三级日本三级久久99| 亚洲国产日韩一区| 欧美精品一区二区三区在线播放 | 国语自产精品视频在线看一大j8| 亚洲一区一卡| 老巨人导航500精品| 亚洲美女免费精品视频在线观看| 欧美电影在线免费观看网站 | 老色批av在线精品| 亚洲精品免费看| 午夜在线观看欧美| 在线日韩中文| 欧美日韩在线高清| 欧美一区二区三区四区在线观看地址 | 欧美久久九九| 欧美在线一二三| 91久久久在线| 久久久国际精品| 一区二区三区成人| 极品尤物久久久av免费看| 欧美激情在线播放| 午夜久久久久久| 欧美黄网免费在线观看| 亚洲线精品一区二区三区八戒| 国产一区二区三区在线播放免费观看| 欧美国产精品一区| 久久精品国产精品| 夜夜嗨av一区二区三区四季av| 老司机午夜精品视频在线观看| 一区二区三区日韩欧美精品| 1204国产成人精品视频| 国产精品啊啊啊| 久久久蜜桃一区二区人| 亚洲在线一区|