动态库中读取数据库 用过的进来看看

ponydph 2009-09-11 09:32:58
MFC常规DLL。 用ADO连接数据库Sqlserver 2000
在InitInstance()函数中,连接数据库
在ExitInstance()函数中 关闭连接。
测试程序:一个对话框程序,两个按钮 一个动态加载,一个动态卸载。
问题:当加载动态库后,先点卸载按钮,程序正常。当不卸载动态库,直接关闭对话框程序,程序报错。
//代码如下
声明
class CD3App : public CWinApp
{
public:
bool OpenDatabase();
CD3App();
///////////////////
_ConnectionPtr m_pConn;
}

BOOL CD3App::InitInstance()
{
//初始化COM环境
::CoInitialize(NULL);



OpenDatabase();

return CWinApp::InitInstance();
}
bool CD3App::OpenDatabase()
{

CString strCon="driver={SQL Server};Server=(local);DATABASE= test;UID=sa;PWD=sa";
try
{
HRESULT hr=m_pConn.CreateInstance("ADODB.Connection"); //__uuidof(Connection)
if(SUCCEEDED(hr))
{
hr=m_pConn->Open(_bstr_t(m_strCon),"","",adModeUnknown);//
}
}
catch(_com_error &e)
{
return false;
}

if(SUCCEEDED(hr))
return true;
else
return false;
}

int CD3App::ExitInstance()
{
// 关闭连接 释放对象
if( adStateOpen ==m_pConn->State )
{
m_pConn->Close();//当调用程序直接退出的时候 ,报错 }
m_pConn.Release();

::CoUninitialize();

return CWinApp::ExitInstance();
}

//////调用程序 一个对话框(2个按钮)
加载动态库
HMODULE hDll2=NULL
void CDllTestDlg::OnButton3()
{
hDll2=::LoadLibrary("D3.dll");
if(hDll2==NULL)
{
AfxMessageBox("加载D3.dll库失败",MB_ICONWARNING);
return;
}

}
//卸载动态库
void CDllTestDlg::OnButton4()
{
if(hDll2!=NULL)
FreeLibrary(hDll2);
}

//如果按照 正常顺序操作 即 加载 -- 卸载,则程序不会有问题
如果加载后,不卸载,直接关闭对话框测试程序,则程序会报错。请问为什么。谢谢

...全文
96 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
蒋晟 2009-09-12
  • 打赏
  • 举报
回复
不要在InitInstance和ExitInstance里面创建数据库连接。参考MSDN中关于DLLMain的说明
ponydph 2009-09-11
  • 打赏
  • 举报
回复
继续顶
ponydph 2009-09-11
  • 打赏
  • 举报
回复
一样的 ,
jameshooo 2009-09-11
  • 打赏
  • 举报
回复
用AfxLoadLibrary/AfxFreeLibrary
ponydph 2009-09-11
  • 打赏
  • 举报
回复
跟踪到Close()函数里面去,发现是HRESULT _hr = raw_Close();报错。
弹出的错误如下:
Unhandled exception in DllTest.exe (MSDART.Dll):0xC0000005:Access Violation

如果按着加载LoadLibrary 再卸载FreeLibary的顺序 在关闭调用程序 则没有问题。
如果不卸载 直接关闭调用程序,则报错
dirdirdir3 2009-09-11
  • 打赏
  • 举报
回复
try{
m_pConn->Close();//当调用程序直接退出的时候 ,报错 }
m_pConn.Release();
}
catch(....)

看看是什么错误.....
jxufeng 2009-09-11
  • 打赏
  • 举报
回复
不卸载,应该就是下面的消息没有执行
::ExitInstance()
导致了ado没有关,资源没有释放吧
flyskytoday 2009-09-11
  • 打赏
  • 举报
回复
你在关闭窗口的消息里面加判断退出
if(hDll2!=NULL)
FreeLibrary(hDll2);

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧