無法解析的外部符號 "public: static void __cdecl std::_String_base::_Xran(void)" (?_Xran@_String_base@std@@SAXXZ)"


采用下面的方法。重新編譯了一下依賴的庫,OK了。

  問題描述:

      今天用VS2010編譯一個在VS2008下Coding的工程的時候,VS給出了一堆鏈接錯誤信息,如下圖所示:

       

      在ErrorList里面列出了34個鏈接錯誤信息,但仔細看的話,其實很多都是重復的,只有兩三個外部符號未正確解析,如下:

      "public: static void __cdecl std::_String_base::_Xran(void)" (?_Xran@_String_base@std@@SAXXZ)

      "public: static void __cdecl std::_String_base::_Xlen(void)" (?_Xran@_String_base@std@@SAXXZ)

       

       問題分析: 

       首先,可以確定是程序在Build(構建)過程中,鏈接靜態鏈接庫libprotobuf.lib的時候出現外部符號無法解析的問題,而且可以看出 libprotobuf.lib庫中的很多的中間目標文件(Windows下以.obj作后綴名的文件)都對此外部符號存在着引用,但在符號重定位時候卻 在全局符號表中找不到引用的符號。        

       而_Xran和_Xlen這兩個符號到底是什么呢,通過google可以大致了解到時string類里面的兩個符號,難道問題出在對於string類的引 用么?那么我們可以通過下術的步驟來觀察一個引用string頭文件的源文件經過IDE的預處理后是怎么樣的   

      1、新建一個名為Test.CPP文件,內容很簡單,只是包含一個string頭文件,即#include<string> 

    2、打開VS帶的Command Prompt,輸入命令 CL /EP Test.cpp > D:\\1.txt

      上述命令為使用MSVC的編譯器對Test.cpp進行預處理操作,並將內容重定向到1.txt中。    

      情況一:

      如果你用的VS2005或者VS2008下的命令行工具的話,在打開1.txt后其實可以搜索到如下的內容:

      

      

      情況2

      如果你使用的是VS2010的話,那么在產生的1.txt中搜索_Xlen與_Xran的話,則為如下的內容:

       

       補充:其中第二個_Xran與_Xlen是在類basic_string中定義的,顯然與VS2005與VS2008下產生的不同。

      

       問題總結:

       靜態鏈接庫libprotobuf.lib在舊版本IDE上編譯的,所以string類中符號被解析成形如static void __cdecl _Xlen() 

       而在高版本的VS2010上string中的_Xlen與_Xran符號則被解析成了__declspec(noreturn) void _Xlen() const

       所以才會在鏈接過程中出現上述開頭出現的一堆問題

  

       問題解決: 

       第一種方法:

      重新在高版本的IDE下編譯libprotobuf.lib,這種方法最行之有效啦,也很簡單

       第二種方法:

             可以新建一個鏈接庫,導出無法解析的幾個符號,並這幾個符號實現中重定向到VS2010下預處理后的那幾個符號即可。具體參考這個網址:http://social.msdn.microsoft.com/Forums/en/vcgeneral/thread/5ac28a31-3339-4db1-90f4-68edad360309 里面的JN123給出的方法 

 

        歡迎裝載,裝載請注明出處:http://www.cnblogs.com/royenhome


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM