我正在尝试使用带有此代码的VS2010从dll导入一个fonction
// test.cpp : définit le point d'entrée pour l'application console.
//
#include "stdafx.h"
#include<iostream>
#include<windows.h>
#include<map>
#include<string>
using namespace std;
namespace mido{
class ABC_YieldCurve;
}
typedef int (*buildDepoSwapCurve)(mido::ABC_YieldCurve *& depoSwapTermStructure, long asOfDate,
std::map<std::string, double>& depoInstruments, std::map<std::string, double>& swapInstruments, std::string& error );
int _tmain(int argc, _TCHAR* argv[])
{
buildDepoSwapCurve mybuildDepoSwapCurve;
HINSTANCE hinstLib = LoadLibrary(TEXT("YieldCurve.dll"));
if (hinstLib == NULL) {
printf("ERROR: unable to load DLL\n");
cin.get();
return 1;
}
mybuildDepoSwapCurve = (buildDepoSwapCurve)GetProcAddress(hinstLib, "buildDepoSwapCurve");
if (mybuildDepoSwapCurve == NULL) {
printf("ERROR: unable to find DLL function\n");
cin.get();
FreeLibrary(hinstLib);
return 1;
}
//Construction d'un depoInstruments
std::map<std::string,double> mydepoInstruments;
mydepoInstruments["1W"]=0.0382;
mydepoInstruments["1M"]=0.0372;
mydepoInstruments["3M"]=0.0363;
mydepoInstruments["6M"]=0.0353;
mydepoInstruments["9M"]=0.0348;
//Construction d'un swap instrument
std::map<std::string,double> mySwapInstruments;
mySwapInstruments["1Y"]=0.0345;
mySwapInstruments["2Y"]=0.037125;
mySwapInstruments["3Y"]=0.0398;
mySwapInstruments["5Y"]=0.0443;
mySwapInstruments["10Y"]=0.05165;
mySwapInstruments["15Y"]=0.055175;
mySwapInstruments["25Y"]=0.05165;
//l'objet myYieldCurve nul
mido::ABC_YieldCurve * myYieldCurve;
string t="";
cout<< mybuildDepoSwapCurve(myYieldCurve,40000,mydepoInstruments,mySwapInstruments,t)<<endl;;
cout<<"test";
cin.get();
FreeLibrary(hinstLib);
return 0;
}
结果显示dll和函数的导入是成功的。 但我无法理解为什么会有错误(对不起,这是法语) Exceptiondepremièremempareà0x76bdb727dans testWrapper.exe:Exception Microsoft C ++:QuantLib ::Erroràl'enlacementmémoire0x0015f800.. 例外非géréeà0x76bdb727dans testWrapper.exe:异常Microsoft C ++:QuantLib ::错误àl'enlacementmémoire0x0015f800..
但是,我的朋友使用VS2008并且此代码有效 代码停止时的错误是:
{
/*
* The /GS security cookie must be initialized before any exception
* handling targetting the current image is registered. No function
* using exception handling can be called in the current image until
* after __security_init_cookie has been called.
*/
__security_init_cookie();
return __tmainCRTStartup();
}
在文件crtexe.c中 感谢
我已删除了删除/ GS(缓冲区安全检查),但现在问题出现在代码dbgheap.c中
extern "C" _CRTIMP void __cdecl _free_dbg(
void * pUserData,
int nBlockUse
)
{
/* lock the heap
*/
_mlock(_HEAP_LOCK);
__try {
/* allocate the block
*/
_free_dbg_nolock(pUserData, nBlockUse);
}
__finally {
/* unlock the heap
*/
_munlock(_HEAP_LOCK);
}
}
答案 0 :(得分:1)
删除项目设置中的 / GS (缓冲区安全检查):)