请大家支招:主程序持续运行十几个小时后的一些问题.主程的线程每隔几秒扫描一次数据库表信息,还有一个Timer控件.
持续运行十几多小时后出现的现象:
   Timer事件会执行;
   线程不会触发执行;
   调用DLL失败;
   创建有Clientdataset控件的窗体提示"LOAD MIDAS ERROR"和句柄无效;

解决方案 »

  1.   

    1、有没有其它线程操作Timer2、midas升级一下,原来用D5下的好像有bug
      

  2.   

    d版delphi?http://dn.codegear.com/cn/article/20870
      

  3.   

    to hongqi162(失踪的月亮):
      持续运行十几个小时后才会提示LOAD MIDAS ERROR,刚开始运行时没有问题(midas.dll已经有注册过了).
      

  4.   

    to: ljz9425(阿九):
      1.timer控件只有主程序控制enabled
      2.我用的是D7+ORACLE9I
      

  5.   

    重新注册一下MIDAS.DLL再测试看报不报错
      

  6.   

    重新注册一下MIDAS.DLL再测试看报不报错
                      ---试过还是提示LOAD MIDAS ERROR
      

  7.   

    to numbbb(空白的历史1966至1976):
       线程没有更新界面,它主要是读取数据库信息触发事件用的.to hsmserver(撒哈拉之雨的悲伤) :
      没有装特别的软件,除了操作系统就是数据库了.
      

  8.   

    类似用法用, 类同情况无, 还是在事件代码中有分配的 handle 资源没得到释放, handle 有极限, 你从任务管理器中看 gui, 句柄数是否只增不减
      

  9.   

    我也用D7+oracle 9i
    以前出现过的问题是,数据库每天要断掉一次,重启就好了。现在升级成10g再没出现过。
    我想你这个会不会也是数据库的问题,建议问问数据库管理方面的高手。或干脆把数据库升级得了。
      

  10.   

    TO comanche(太可怕) :
      还是在事件代码中有分配的 handle 资源没得到释放, handle 有极限, 你从任务管理器中看 gui, 句柄数是否只增不减.
     ----没错,在我软件里句柄数会只增不减,线程也只增不减.这几天重新检查程序,发现在线程里创建的子线程(即使设置为运行完自动释放,但实际没有释放.)不断增加.现在改后线程数不会累加了,但句柄还会累加没找出原因来.虚拟内存也会一直增加.
      

  11.   

    极有可能是线程句柄或者线程中使用到的资源没得到释放,首先看看Delphi的补丁是不是都打了,然后再查程序,记得以前有个软件叫BoundChecker,分析资源泄露很有效,不知是否有For D7的版本。
      

  12.   

    这种问题无解的啊, 代码质量, 开发这部分作者的精神,经验都有很大关系线程出口要检查, 可能性非常大线程中有没操作 Cds? Cds 数据源是怎么来的? 通过 Data 取得, 还是 CloneCursor(主线.XCds)?? 线程不要去 Clone 主线 Cds, 最终通过 Delta 回写到主线 Cds线程中有没到主线来操作 Cds? Cds 作为 TComponent 派生类, 是线程不安全的, 所有被线程操作的地方都应该同步, 要不然就有极大可能性内存 leak问题在 load midas.dll 不正确, 又操作cds, 主要可能性就那几种
      

  13.   

    在线程中使用ClientDataSet控件是十分不安全的,CDS控件是非线程安全的,长期运行一定会出问题,原来曾做一程序,需要24小时不间断运行,后来把服务部分和显示部分分开为两个程序,服务只是处理数据,并不显示。显示部分才需要CDS等非线程安全控件,你可以按这个思路考虑一下。
      

  14.   

    线程里没有用CDS控件,有用ADOQUERY。谢谢大家的分析,我再查查代码,先结贴了。