甚至未引用的类方法的未解析外部符号
Unresolved external symbol for classmethod that isn't even referenced
我正在创建一个简单的调试线程名称数据库(因为您不能在windows中给线程名称,您只能将该名称发送给调试器)。我有这个头文件:
threadname.h
class ThreadNameMap {
public:
void setThreadName( uint32_t id, const std::string &name );
std::string getThreadName( const uint32_t id ) const;
// If ID given as string
std::string getThreadName( const std::string id ) const;
// If no ID given, current ID is used
std::string getThreadName( ) const;
// A singleton getter
static ThreadNameMap* ThreadNameMap::getInstance();
// Static getters that use the singleton
static std::string getName( const uint32_t id );
static std::string getName( const std::string id );
static std::string getName( );
private:
ThreadNameMap() {maxNameLength = 16;};
int maxNameLength;
// Map of ids and names
std::map<uint32_t, std::string> names;
};
这是实现:
threadname.cpp
<>之前ThreadNameMap::getInstance() {static ThreadNameMap = ThreadNameMap();返回本月;}std::string ThreadNameMap::getName(const uint32_t id) {return getInstance()->getThreadName(id);}std::string ThreadNameMap::getName(std::string id) {return getInstance()->getThreadName(id);}std::string ThreadNameMap::getName() {return getInstance()->getThreadName();}void ThreadNameMap::setThreadName(uint32_t id, const std::string &name) {setThreadName_private (id、name.c_str ());如果(id = = 1)id = boostThreadId();[id] = name;}std::string ThreadNameMap::getThreadName(const uint32_t id)如果名字。Count (id)>0返回names.at (id);其他的返回";}std::string ThreadNameMap::getThreadName(const std::string id)threadNumber = 0;sscanf(id.c_str(), "%lx", &threadNumber);返回getThreadName (threadNumber);}/**这个被报告为未引用!!* */std::string ThreadNameMap::getThreadName() const {返回getThreadName (boostThreadId ());} 之前我使用单例接口,我像这样在我的记录器头文件中访问它:
logger.h
<>之前# include"…路径…/setthreadname.h"#define LOGMTDBG_tmp(debuglevel, logstream) LOGMT(debuglevel (debuglevel) <<datetimeEx & lt; & lt;' ' << ThreadNameMap: getName () & lt; & lt;' ' <<__FUNCTION__ & lt; & lt;' ' <<logstream) 之前Logger包含在许多其他cpp
和h
文件中-无论需要什么地方。其中一些报告未引用的符号:
我搜索了项目,但是没有任何一个类非静态方法的引用,只有 logger.h
中的一个。
我检查了许多未引用的外部符号问题,但它们都有两种可能性:
- dll缺失-好吧,我没有使用任何dll显然
- 函数已声明但未实现——在上面的代码中,您可以看到声明和实现以及它们都匹配
那么为什么链接器会抱怨没有被引用的方法呢?我试图改变const
和移动.h
文件中的静态方法,没有任何帮助。我现在真的很绝望。
编辑: Visual studio链接器标志:
/OUT:"D:techsysRomeoTTPROJECTPROJECTd.exe" /INCREMENTAL /NOLOGO /LIBPATH:"....libsopenssl64libVCstatic" /LIBPATH:"....libsboost155stagelib64bit" /LIBPATH:"C:Qt5.3.0-64qtbaselib" "libeay32MTd.lib" "Graph64d.lib" "HelpLib64d.lib" "version.lib" "qtmaind.lib" "Qt5Cored.lib" "Qt5Guid.lib" "Qt5Multimediad.lib" "Qt5Sqld.lib" "Qt5PrintSupportd.lib" "Qt5Svgd.lib" "Qt5Widgetsd.lib" "Qt5Xmld.lib" "Qt5XmlPatternsd.lib" "kernel32.lib" "user32.lib" "gdi32.lib" "winspool.lib" "comdlg32.lib" "advapi32.lib" "shell32.lib" "ole32.lib" "oleaut32.lib" "uuid.lib" "odbc32.lib" "odbccp32.lib" /MANIFEST /ManifestFile:"D:techsysXXXXobjx64XXXXDebugXXXXXd.exe.intermediate.manifest" /ALLOWISOLATION /MANIFESTUAC:"level='asInvoker' uiAccess='false'" /DEBUG /PDB:"D:techsysXXXXXXXXXX64XXXXXd.pdb" /SUBSYSTEM:WINDOWS /OPT:NOREF /PGD:"D:techsysXXXXXXXX64XXXXXd.pgd" /TLBID:1 /DYNAMICBASE /NXCOMPAT /MACHINE:X64 /ERRORREPORT:NONE
您可以通过详细检查错误消息(已清除以确保可见性)来找到可能的罪魁祸首:
<>之前未解析的外部符号"string stringThreadNameMap::getThreadName(void)"在RunWindow.obj中被引用未解析的外部符号"string stringThreadNameMap::getThreadName(void)"在函数"private: void stringBaseRunPresenter::MessageHandler(class boost::shared_ptr)"中被BaseRunPresenter.obj引用未解析的外部符号"string stringThreadNameMap::getThreadName(void)"在BaseRunView.obj中被引用xmlsestavarunpresent .obj中引用的未解析的外部符号"stringThreadNameMap::getThreadName(void)"在RunSestavaFrame.obj中引用的未解析的外部符号"string stringThreadNameMap::getThreadName(void)"未解析的外部符号"string stringThreadNameMap::getThreadName(void)"在函数"public: void stringSestavaHeader::DataSource::Dump2LOG(void)const " SestavaDataSource.obj之前这些链接错误说明:
- 一些对象文件(RunWindow。obj, BaseRunPresenter.obj…)包含对非const方法
getThreadName()
的引用。 - 这意味着当方法
getThreadName()
被声明为非const 时,这些目标文件已经从源文件生成
getThreadName()
的声明现在是const:
std::string getThreadName( ) const;
因此,这些目标文件中的每一个都是基于过时的getThreadName()
声明编译的,应该重新编译。如果可能,因为可能存在其他(未检测到的)不一致错误,您应该执行完整的重新构建。
相关文章:
- C++:Application.cpp中抛出了未解析的外部符号(解决方案在问题的末尾,供未来的读者参考)
- 未解析的外部符号_MsiLocateComponentW@12.
- 在C++中使用 gRPC 时未解析的外部符号
- LibPrivoxy: 未解析的外部符号 __declspec(dllimport) int __stdcall Sta
- 尝试从 XamlApplication 编译 C++/WinRT 空白应用程序时,我收到未解析的外部符号 winrt_make_*
- 我收到错误LNK2001:未解析的外部符号(C++代码)
- 可视抽象类 c++(错误 LNK 2001:未解析的外部符号)
- 如何摆脱C++中未解析的外部符号"private: static char"错误?
- 当 lib 已添加到其他依赖项时,如何在 VS 中调试未解析的外部符号错误
- 仅在少数方法(静态或共享库)中解析的外部符号
- 未解析的外部符号"__declspec(dllimport)与 Spdlog c++ 库
- 函数 _main (OPENGL C++) 中引用的未解析的外部符号 ________
- 错误LNK2019未解析的外部符号"public: __thiscall SLinkList<char>::SLinkList<char>(void)"
- 使用静态 constexpr 成员的未解析外部符号
- 引入参数化构造函数后显示 LNK 2019 未解析外部符号的代码错误
- Dlib LNK2001未解析的外部符号USER_ERROR__consistent_build_configurati
- 矛盾的未解决的外部符号+未使用的库与VS2017和FFMPEG 4
- 链接器错误:切换到unicode生成给出:未解析的外部符号WinMain
- 类模板上一个特定函数的未解析外部符号
- LNK2001:未解析的外部符号public:static类std::vector