导入DLL并在C ++中使用extern函数

时间:2012-02-05 16:31:59

标签: c++ dll linker

这一定是一个基本问题,但我现在很长时间都在努力解决这个问题。 我在谷歌的任何地方都看过,发现了一些类似的问题和解决方案,但没有解决我的具体问题。

我写了一个非常基本的C ++ DLL。实际上它几乎是C风格,因为DLL只有一个带有函数的main.cpp代码文件,因此它甚至不使用类。

然后我有两个头文件:

MqlUtils.h:

#ifndef MQLUTILS_H
#define MQLUTILS_H

struct MqlStr
{
    int len;
    char *string;
};

enum TradeOperation
{
    OP_BUY = 0,
    OP_SELL = 1,
    OP_BUYLIMIT = 2,
    OP_SELLLIMIT = 3,
    OP_BUYSTOP = 4,
    OP_SELLSTOP = 5
};

#endif

main.h:

#ifndef _DLL_H_
#define _DLL_H_

#include "MqlUtils.h"

#define MT4_EXPFUNC __declspec(dllexport)

#define export extern "C" __declspec( dllexport )

 MT4_EXPFUNC int __stdcall  GetOrdersDetailsNoSymbol(const int orderCount, const char * MasterLicense, const char * SlaveLicense, int orderTicket[], int op[],
    double orderOpenPrice[], double orderStoploss[],
    double orderTakeProfit[], double orderLots[], int orderDateTime[],
    MqlStr * ordersymbol, MqlStr * ordercomments, int lotsCopyingMethod[], int returnedOrders[]);

#endif /* _DLL_H_ */

事实上,为了创建我的DLL,我开始使用其他人编写的现有代码,因此我的DLL的.cpp文件有一些模糊的语法,我甚至不确定它在做什么。这是.cpp看起来像的摘录:

#include "main.h"

#define _UNICODE 1
#define UNICODE 1
#define WIN32_LEAN_AND_MEAN

// ...

EXTERN_C IMAGE_DOS_HEADER __ImageBase;


#if BUILDING_DLL
#define DLLIMPORT __declspec (dllexport)
#else /* Not BUILDING_DLL */
#define DLLIMPORT __declspec (dllimport)
#endif /* Not BUILDING_DLL */

// ...

#ifdef __cplusplus
extern "C"
{
#endif

// ... function code

#ifdef __cplusplus
}
#endif

我没有包含.cpp文件中的所有内容,其中有// ...还有其他东西,但它是我理解的基本内容,所以它不应该是我的问题的根源......我很乐意根据需要发布更多信息。

我不是像__declspec这样的所有模糊关键字的专家,但是DLL本身可以成功导入,并且函数GetOrdersDetailsNoSymbol可以被某些程序使用,即MetaTrader 4(这是主要目标我的lib。。

但是现在我希望能够用C ++程序测试我的库,所以我创建了一个空的控制台程序,将库项目添加到测试项目的引用中,并通过测试项目链接.obj和.h文件属性。

我正在编译测试项目时得到这个:

Error   2   error LNK1120: 1 unresolved externals   Z:\Codes\Debug\TestsCpp.exe TestsCpp
Error   1   error LNK2019: unresolved external symbol "__declspec(dllimport) int __cdecl GetOrdersDetailsNoSymbol(int,char *,char *,int * const,int * const,double * const,double * const,double * const,double * const,int * const,struct MqlStr *,struct MqlStr *,int * const,int * const)" (__imp_?GetOrdersDetailsNoSymbol@@YAHHPAD0QAH1QAN2221PAUMqlStr@@311@Z) referenced in function "void __cdecl TestClient(void)" (?TestClient@@YAXXZ)    Z:\Codes\TestsCpp\main.obj  TestsCpp

哦,这是测试项目的main.cpp:

#include "MqlUtils.h"
#include "main.h"

extern __declspec(dllimport) int GetOrdersDetailsNoSymbol(int orderCount, char * MasterLicense, char * SlaveLicense, int orderTicket[], int op[],
    double orderOpenPrice[], double orderStoploss[],
    double orderTakeProfit[], double orderLots[], int orderDateTime[],
    MqlStr* ordersymbol, MqlStr* ordercomments, int lotsCopyingMethod[], int returnedOrders[]);


void TestClient()
{
   char* Master = "7C83C4C2";
   char* Slave = "3B7C22A";

   int returnedOrderCount[1] = {0};

   double aStoredOrderOpenPrice[4];
   int aStoredOrderType[4];
   int aStoredOrderTicket[4];
   double aStoredOrderStopLoss[4];
   double aStoredOrdeTakeProfit[4];
   double aStoredOrderLots[4];
   int aStoredOrderDateTime[4];
   int aStoredLotsMethods[4];
   MqlStr* aStoredOrderComment[4];
   MqlStr* aStoredOrderSymbol[4];

   for (int i = 0; i < 4; i++)
   {
      aStoredOrderOpenPrice[i]= -1;
      aStoredOrderType[i]= -1;
      aStoredOrderTicket[i]= -1;
      aStoredOrderStopLoss[i]= -1;
      aStoredOrdeTakeProfit[i]= -1;
      aStoredOrderLots[i]= -1;
      aStoredOrderDateTime[i]= -1;
      aStoredLotsMethods[i]= -1;

      aStoredOrderComment[i]->len = 56;
      aStoredOrderComment[i]->string = "11111111111111111111111111111111111111111111111111111111";
      aStoredOrderSymbol[i]->len = 56;
      aStoredOrderSymbol[i]->string = "11111111111111111111111111111111111111111111111111111111";
   }


   GetOrdersDetailsNoSymbol(1, Master, Slave, aStoredOrderTicket,  aStoredOrderType,
                                            aStoredOrderOpenPrice, aStoredOrderStopLoss,
                                            aStoredOrdeTakeProfit, aStoredOrderLots, aStoredOrderDateTime,
                                            *aStoredOrderSymbol, *aStoredOrderComment,     aStoredLotsMethods, returnedOrderCount);
}

int main(int argc, char **argv)
{
   TestClient();

   return 0;
}

如果有人能帮助我解决这个问题,我会非常感激。

感谢阅读!

1 个答案:

答案 0 :(得分:3)

您的两个GetOrdersDetailsNoSymbol声明不匹配。在头文件中,您使用__stdcall声明它,而在main.cpp中则不是。你应该只有一个声明。它可以使用#define和#ifdef来适当地应用dllimport或dllexport关键字。

编辑:另外,摆脱extern“C”语句。然后使用DLLIMPORT #define声明您的函数,并在DLL的构建中仅使用#define BUILDING_DLL。