高分求助 delphi 线程池使用问题!

来源:百度知道 编辑:UC知道 时间:2024/06/16 23:31:13
最近想做一个东西,开始用多线程,但发现线程数开了一定数量后就说没空间分配了。。 后听说有一种叫线程池东西更高效,于是百度几天,发现一贴里有一个封装好的,但我不会用啊,求大侠们给个简单的例子,针对这个封装好的。
那个封装好的在这个地址:
http://www.fjsnow.com/tcbbs/thread-206-1-1.html
他里面给的使用方法 编译通不过啊
请帮我弄个一例子,实现一按按钮就能并行处理abcde过程。
另问下:用这个东东 一下并发1000任务有问题吗?

我是一初学者,没基础。。 解决了追加送分
欢迎通过HI来指点 嘿嘿,谢了

这种东西超级没有意思的。
线程池的实现不难,关键你的设计要好,能处理所有的异常。
不然线程出了错不是好玩的。
如果你不是必要的话,不要使用线程。

cnpack里有一个,简单的话就用AsyncCalls,再简单的话只有自写了

优秀的数据库应用应当充分考虑数据库访问的速度问题。通常可以通过优化数据库、优化 查询语句、分页查询等途径收到明显的效果。即使是这样,也不可避免地会在查询时闪现一个带有 SQL符号的沙漏,即鼠标变成了查询等待。最可怜的是用户,他(她)在此时只能无奈地等待。遇到急性子的,干脆在此时尝试 Windows中的其它应用程序,结果致使你的数据库应用显示一大片白色的窗口。真是无奈!

本文将以简单的例子告诉你如何实现线程查询。还等什么,赶快打开Delphi对照着下面的完整源代码试试吧。

在查询时能够做别的事情或者取消查询,这只是基本的线程查询,在你阅读了Delphi有关线程帮助之后能立刻实现。这里介绍的是多个线程查询的同步进行。

在Delphi数据库应用中,都有一个缺省的数据库会话 Session。通常情况下,每个数据库应用中只有这一个会话。无论是查询函数修改数据,在同一时间内只能进行其中的一件事情, 而且进行这一件事情的时候应用程序不能响应键盘、鼠标以及其它的 Windows消息。这就是在 窗口区域会显示一片空白的原因所在。当然,只要将查询或数据操纵构造成线程对象,情况会好一些,至少可以接受窗口消息,也可以随时终止查询或数据操纵,而不会在屏幕上显示出太难看的白色。不过,这只是解决了问题的一部分。假如在进行一个线程查询的时候,用户通过 按钮或菜单又发出了另一个查询的命令,这可如何是好,难道终止正在执行的数据库访问吗? 解决之道就是:多线程同步查询。

实现多线程同步查询的基本思想是,为每一个查询组件(如TQuery组件)创建一个独占的 数据库会话,然后各自进行数据库访问。需要特别注意的是,因为Delphi中的 VCL组件大多都 不是线程安全的,所以应当在线程查询结束后再将DataSource组件与查询组件关联,从而显示 在DBGrid组件中。

下面的例子只实现了静态的线程同步查询,即线程