开发过indy以及用过ADO的,请进来帮一下忙!

zhgwbzhd 2010-09-20 06:36:19
我用的是indy9,在IdTCPServer的OnExecute事件内。使用ADO。对SQL进行统计。

ADOConnection_Auto = new TADOConnection(NULL);
ADOQuery_Auto = new TADOQuery(NULL);

ADOConnection_Auto->Close();
ADOConnection_Auto->LoginPrompt = false;
ADOConnection_Auto->ConnectionString = ADOConnection_ok->ConnectionString;
ADOConnection_Auto->Open();

ADOQuery_Auto->Connection = ADOConnection_Auto;

这里是代码,使用ADOQuery。

try
{
//下面准备销毁这些
ADOQuery_Auto->Close();
ADOConnection_Auto->Close();

delete ADOQuery_Auto;
delete ADOConnection_Auto;
}
catch(...)
{
Write_LOG("删除ADO出错!");
}


//不知道上面的做法怎么不正确。会出很多"删除ADO出错!"的日志。
...全文
95 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhgwbzhd 2010-09-21
  • 打赏
  • 举报
回复
问题在于有些客户那里使用。
没有这些错误日志啊。

也就是正常的运行。

就是在这个客户这里。出现了这样的错误日志。

每天少则几条,多则上千条了。

为了这个快有点疯了。
周药师 2010-09-21
  • 打赏
  • 举报
回复
这些办法都是不能解决根源的;
断点调试一下,看看具体错误在哪里,然后修改之
不然始终会出大问题的
zhgwbzhd 2010-09-21
  • 打赏
  • 举报
回复
请妖哥仔细看一下我的代码。
由于csdn自动把tab给取消了。
造成格式混乱。

try
{

DOConnection_Auto = new TADOConnection(NULL);
ADOQuery_Auto = new TADOQuery(NULL);

ADOConnection_Auto->Close();
ADOConnection_Auto->LoginPrompt = false;
ADOConnection_Auto->ConnectionString = ADOConnection_ok->ConnectionString;
ADOConnection_Auto->Open();

ADOQuery_Auto->Connection = ADOConnection_Auto;

try
{

这里是代码,使用ADOQuery。
}
catch(...)
{
Write_LOG("使用过程中出错!");
}

//即便是上面使用的代码出错,也会执行下面的代码吧,我是这么理解的。

try
{
//下面准备销毁这些
ADOQuery_Auto->Close();
ADOConnection_Auto->Close();

delete ADOQuery_Auto;
delete ADOConnection_Auto;
}
catch(...)
{
Write_LOG("删除ADO出错!");
}
}
catch(...)
{
Write_LOG("创建ADO出错!");
}
僵哥 2010-09-20
  • 打赏
  • 举报
回复
为什么在catch之后不记录下来具体的错误内容呢?
songqi1227 2010-09-20
  • 打赏
  • 举报
回复
全部都是高手啊
songqi1227 2010-09-20
  • 打赏
  • 举报
回复
谁知道 pwpack20080320 哪里下载啊 修改武器外观的
ccrun.com 2010-09-20
  • 打赏
  • 举报
回复
你这样子try...catch,如果中间有代码执行出错,会有内存的泄露的可能啊。不信你加个断点试试,如果中间有代码出错,delete ADOQuery_Auto未必能执行到。

try...finally组合可以保证finally段内的代码即使前面有异常也能正常执行到。
zhgwbzhd 2010-09-20
  • 打赏
  • 举报
回复
还是妖哥强。
我也发现这个问题了。
不过我现在改成这样了。明天给客户测试一下。

try
{

DOConnection_Auto = new TADOConnection(NULL);
ADOQuery_Auto = new TADOQuery(NULL);

ADOConnection_Auto->Close();
ADOConnection_Auto->LoginPrompt = false;
ADOConnection_Auto->ConnectionString = ADOConnection_ok->ConnectionString;
ADOConnection_Auto->Open();

ADOQuery_Auto->Connection = ADOConnection_Auto;

try
{

这里是代码,使用ADOQuery。
}
catch(...)
{
Write_LOG("使用过程中出错!");
}

try
{
//下面准备销毁这些
ADOQuery_Auto->Close();
ADOConnection_Auto->Close();

delete ADOQuery_Auto;
delete ADOConnection_Auto;
}
catch(...)
{
Write_LOG("删除ADO出错!");
}
}
catch(...)
{
Write_LOG("创建ADO出错!");
}
ccrun.com 2010-09-20
  • 打赏
  • 举报
回复
你这个try...catch用的不合适。应该这样用:
ADOConnection_Auto = new TADOConnection(NULL);
ADOQuery_Auto = new TADOQuery(NULL);

try
{
try
{
ADOConnection_Auto->Close();
ADOConnection_Auto->LoginPrompt = false;
ADOConnection_Auto->ConnectionString = ADOConnection_ok->ConnectionString;
ADOConnection_Auto->Open();

ADOQuery_Auto->Connection = ADOConnection_Auto;

// 这里是代码,使用ADOQuery。
}
catch(...)
{
Write_LOG("删除ADO出错!");
}
}
__finally
{
ADOQuery_Auto->Close();
ADOConnection_Auto->Close();

delete ADOQuery_Auto;
delete ADOConnection_Auto;
}
zzbinfo 2010-09-20
  • 打赏
  • 举报
回复
我也觉得楼主的代码没有什么问题呀,是不是其他地方有问题了
周药师 2010-09-20
  • 打赏
  • 举报
回复
楼主的这段代码看不出错误,检查其他地方吧
是不是
try
{
//这里还有代码,这里出错的?
//下面准备销毁这些
ADOQuery_Auto->Close();
...
zhgwbzhd 2010-09-20
  • 打赏
  • 举报
回复
2楼的意思是:

ry
{
//下面准备销毁这些
ADOQuery_Auto->Free();
ADOConnection_Auto->Free();
}
catch(...)
{
Write_LOG("释放ADO出错!");
}
我不懂电脑 2010-09-20
  • 打赏
  • 举报
回复
用ADOQuery_Auto->Free()
使用TIdAntiFreeze对抗“冻结”   Indy使用一个特殊的组件TIdAntiFreeze来透明地解决客户程序用户界面“冻结”的问题。TIdAntiFreeze在Indy内部定时中断对栈的调用,并在中断期间调用Application.ProcessMessages方法处理消息,而外部的Indy调用继续保存阻塞状态,就好像TIdAntiFreeze对象不存在一样。你只要在程序中的任意地方添加一个TIdAntiFreeze对象,就能在客户程序中利用到阻塞式Socket的所有优点而避开它的一些显著缺点。   Indy使用了线程技术   阻塞式Socekt通常都采用线程技术,Indy也是如此。从最底层开始,Indy的设计都是线程化的。因此用Indy创建服务器和客户程序跟在Unix下十分相似,并且Delphi的快速开发环境和Indy对WinSock的良好封装使得应用程序创建更加容易。   Indy服务器模型   一个典型的Unix服务器有一个或多个监听进程,它们不停地监听进入的客户连接请求。对于每一个需要服务的客户,都fork一个新进程来处理该客户的所有事务。这样一个进程只处理一个客户连接,编程就变得十分容易。   Indy服务器工作原理同Unix服务器十分类似,只是Windows不像Unix那样支持fork,而是支持线程,因此Indy服务器为每一个客户连接分配一个线程。   图1显示了Indy服务器的工作原理。Indy服务器组件创建一个同应用程序主线程分离的监听线程来监听客户连接请求,对于接受的每一个客户,都创建一个新的线程来为该客户提供服务,所有与这一客户相关的事务都由该线程来处理。   使用组件TIdThreadMgrPool,Indy还支持线程池。   线程与Indy客户程序   Indy客户端组件并未使用线程。但是在一些高级的客户程序中,程序员可以在自定义的线程中使用Indy客户端组件,以使用户界面更加友好。

1,178

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder 数据库及相关技术
社区管理员
  • 数据库及相关技术社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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