尝试使用 DLL 项目中的类时出现LNK2019错误 [重复]

LNK2019 error when trying to use a class from a DLL project [duplicate]

提问人:user3797103 提问时间:7/17/2015 更新时间:7/17/2015 访问量:1207

问:

我正在为我的项目开发一个目录观察器类。它在 c++ 中的 .dll 类型项目。我使用 Visual Studio 2013 作为我的 IDE。

我遵循了以下基本步骤:

1.创建了一个 dll 和 c++ 语言类型的新项目

2.新增类和dllExport类型声明

3.构建项目

4.创建控制台应用类型的新项目

5.在dll项目中添加引用(两个项目在不同的目录下)

6.指向“其他包含文件”中头文件的路径

但是在编写了一些使用编译时出现以下错误

Error   1   error LNK2019: unresolved external symbol "public: __thiscall DirectoryWatcher::DirectoryWatcher(void)" (??0DirectoryWatcher@@QAE@XZ) referenced in function "void __cdecl `dynamic initializer for 'watcher''(void)" (??__Ewatcher@@YAXXZ) C:\Users\Karthik\documents\visual studio 2013\Projects\ConsoleApplication2\ConsoleApplication2\Source.obj   ConsoleApplication2*

但是 Dll 项目构建成功

一开始,我错误地指向析构函数,但在标头本身中编写实现(空,只需大括号 { })后。该错误被指向构造函数的错误所取代

她的头文件

#define _SCL_SECURE_NO_WARNINGS

#ifdef DIRECTORYWATCHER_EXPORTS
#define APITYPE __declspec(dllexport)
#else
#define APITYPE __declspec(dllimport)
#endif


#if defined(_WIN32) 
#define PLATFORM_WINDOWS
#elif __APPLE__
#define PLATFORM_MAC
#elif __linux
#define PLATFORM_LINUX
#endif
//-------------------------------------------
// Code Begins Here
//---------------------------------
#ifndef DIRECTORY_WATCHER_H
#define DIRECTORY_WATCHER_H

#define USE_DIRENT



//------------------------
// Includes
//--------------
#include<vector>
#include<iostream>
#include<fstream>
#include<string>
#include<sys\stat.h>
#include <tchar.h>
#include<map>

#ifdef PLATFORM_WINDOWS
#include<Windows.h>
#endif

#ifdef USE_BOOST
#include<boost/filesystem.hpp>
#include <boost/uuid/uuid.hpp>
#include <boost/uuid/uuid_io.hpp>
#include <boost/uuid/random_generator.hpp>
#include <boost/lexical_cast.hpp>
#endif

#ifdef USE_DIRENT
#include <dirent.h>
#endif

using namespace std;

//Meta File
template<typename T>
struct Meta
{
    string Name,Path;
    size_t GUID;
     float Size;
    int Type;

    // Can be anything like list of name or list of animation files or list of folder with a folder
     vector<T> MetaInfo;

};



//---------------------------------------------
// TYPE DEFS
//-------------------------------------

APITYPE typedef  hash<string> HashFunction;
APITYPE typedef Meta<string> FOLDER_META;


struct ChildrenTree
{
    vector<Meta<string>> Children;

};
struct DirectoryTree
{

    string ParentPath;
    //map<Children Name,Related Info>
    map<string, FOLDER_META> Child;

};

struct Changed_Data
{
    FOLDER_META Old;
    FOLDER_META New;
};

//------------------------------------
//operators
//------------------------------------


#ifdef USE_DIRENT
class DirectoryWatcher
{
    //-----------------Type Defs------------------------

    //typedef Meta<string> FOLDER_META;
public:
    //Varaibles
    FOLDER_META defaultMeta;
    Meta<DirectoryTree> TreeMeta;

    // Default Constructor
    DirectoryWatcher(void);


    ~DirectoryWatcher(void){}  // Eror at first pointed to the destructor which was solved by defining it here its self 

    // Obtains a list of files and folders in a directory
    APITYPE void GetList(const string&, vector<FOLDER_META>* ReturnValue ,FOLDER_META* ThisDireMeta);

    // Searches and Returns the pathto the file
    APITYPE bool FindFile(const string& Path
        ,const string& FileName // File Name
        , string* Ret //Path Returned 
        );

    //Update and check to see if a file as moved or added or changed 
    // Monitor(vector<FOLDER_META>* ChangedFiles,bool* FilesChanged -> return types); 
    APITYPE void Monitor(vector<Changed_Data>* ChangedFiles,bool* FilesChanged);

    // Creates a GUID for a file 
    APITYPE size_t CreateGUID(const string& fileName);

    //Export metadata
    APITYPE void ExportMeta(const string& Path,FOLDER_META meta);
    // Get the meta data
    APITYPE  void GetFolderMeta(const string& Path,Meta<string> * ReturnValue );

    //InitalizeMethod 
    // False if path invalid
    // true if path correct
    APITYPE bool Init(const string& Path //Path to the Project folder (The folder to watch)
        );

    APITYPE bool Init(const string& Path //Path to the Project folder (The folder to watch)
        ,vector<FOLDER_META> * Returnmetas);

    APITYPE void MakeDir(const string& path);


private:

    string Project_Path;
    DIR* dir = nullptr;
    DIR* MainDir = nullptr;
    struct dirent* ent = nullptr;
    DIR* tempDir = nullptr;
    DirectoryTree Tree;
    HashFunction hashFunc;

    //Dpeth Search 
    DirectoryTree UnVisited;


    //-------------------------------------
    // Windows Specifif cCode
    //---------------------------------
    HANDLE ChangeNotifications[2];
    TCHAR lpDrive[4];
    TCHAR lpFile[_MAX_FNAME];
    TCHAR lpExt[_MAX_EXT];
    DWORD Notifications; 



    // Private methods
    APITYPE long GetFolderSize( const string& Path);
    APITYPE bool CheckPathValid(const string& Path);

    APITYPE void RefreshFiles(vector<Changed_Data>* ChangedFiles,const string& path,bool OnlyThisFolder);
    APITYPE void RefreshTree(vector<Changed_Data>* ChangedFiles, const string& path);
    APITYPE void CreateTree(const string& Path );

    APITYPE void SaveTree();
    APITYPE void LoadTree();
    APITYPE bool AreChildEqual(const FOLDER_META& metaA,const FOLDER_META& metaB );
};
#endif

#endif // !DIRECTORY_WATCHER_H

*我省略了实现部分,因为它非常大,但这里只有构造函数 *

目录观察者.cpp

  DirectoryWatcher::DirectoryWatcher(void)
    {

      Project_Path = "";
      dir = nullptr;
      MainDir = nullptr;
      ent = nullptr;
      tempDir = nullptr;
    }

The TestAplication

来源:.cpp

#include<DirectoryWatcher.h>


using namespace std;




DirectoryWatcher watcher;

// omitted part of code 
int main(int argv, char* argc) 
{
    string Path;
    cout << "enterPath";
    cin >> Path;

    bool ISCahnged;
    vector<FOLDER_META> metas,Returnvalues;
    vector<Changed_Data> changedDatas;
    watcher.Init(Path, &Returnvalues);

    while (true)
    {
        ISCahnged = false;
        watcher.Monitor(&changedDatas, &ISCahnged);

        if (ISCahnged)
        {
            for each (Changed_Data var in changedDatas)
            {
                OutChangedData(var);
            }
        }

    }

    return 0;
}

为较小的代码省略了几行

任何人都可以好心地帮助解决问题吗

谢谢

C++ dll visual-studio-2013 链接器错误

评论

0赞 Niall 7/17/2015
这个答案可能会有所帮助 stackoverflow.com/a/12574423/3747990
0赞 Anton Savin 7/17/2015
您应该使用 .class DirectoryWatcherAPITYPE
0赞 user3797103 7/17/2015
谢谢你们,非常感谢,我不知道我只需要在课程开始时使用 dllexport

答:

1赞 Breandán Dalton 7/17/2015 #1

您需要从 dll 中导出类。这里有一个很好的答案:从 DLL 导出 C++ 类