多线程技术在Delphi数据库编程中应用 (1)

2008-02-23 07:14:10来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

1 2 3 下一页

引言

在传统上,并发多任务的实现采用的是在操作系统级运行多个进程,由操作系统按照一定的策略(优先级、循环等),调度各个进程的执行,以最大限度的利用计算机的各种资源。在这种实现方法中最基本的调度单位是操作系统级上的进程。由于各个进程拥有自己独立的运行环境(寄存器和地址空间等)。进程与进程之间的耦合关系差,并发性粒度过于粗糙,并发实现也不太容易。所以,除非特殊需要,一般的应用设计都不采用这种技术。

为了克服这些问题,近年来逐步发展了并发多线程的程序设计技术。从并发Ada、并发C等各种并发多任务的程序设计语言(这些语言中采用的虽然不是线程这个术语,但其基本思想是一样的),到Mach、Chorus、Solaris System等各种采用了线程技术的系统,多线程技术得到了迅速发展和日益广泛的应用。IEEE也推出了有关多线程程序设计的标准POSIX1003.4a。特别是在Window NT和Windows 98等流行操作系统中,采用了线程作为基本的调度单位,其API中也提供了有关线程操作的用户程序接口。所有这些无疑都会促进多线程技术在程序设计中被日益广泛的采用。

多线程技术的概念

所谓线程(或称线索,thread),指程序中的以单一的顺序控制流。线程按顺序执行,即在一个线程中,一个时刻只能由一个执行点。显然,按传统方法设计的程序,无论是单道执行的程序,还是由多个进程并发执行的多道程序,就每个程序本身而言,都是由单线程组成的。

多线程程序设计,就是使单个程序中包含并发执行的多个线程。当多线程程序执行时,在该程序对应的进程中就有多个控制流在同时运行,即具有并发执行的多个线程。在一个进程中包含并发执行的多个控制流,而不是把多个控制流一一分散在多个进程中,这是多线程程序设计与并发多进程程序设计截然不同之处。这就决定了二者之间虽然在概念上有许多相通之处,但实现方法则是完全不同。

许多多任务操作系统限制用户能拥有的最多进程数目,如很多Unix版本的典型值为20个左右,这对许多并发应用来说远远不够。而对多线程技术来说,不存在这样的数目限额。

多线程程序设计

线程是系统调度的基本单位,是CPU的一条执行路径。一个应用程序实例至少有一个线程,即程序的基本线程或主线程。用户可以根据需要同时创建若干个线程,让一个程序在同一时刻运行多个线路。线程间独立运行,每个线程都轮流占用CPU的运行时间和资源,即将CPU的时间分片,每一个时间片给不同的线程使用。这样,操作系统将不断的将线程挂起、唤醒、再挂起、再唤醒,直至完成整个任务。

当程序在运行时,线程被加载到内存中等待执行。每个线程都可能包含该应用程序的数据、代码或者其他操作系统的资源。一个线程执行程序的一部分,所有线程都能够访问进程的全局变量。

一个采用多线程的应用程序允许同一程序的多个部分同时执行,为程序赋予了并行特性,因而可以执行某些实时性或随机性很强的操作,提高对CPU的利用率,加快信息处理速度。

上一篇: 用Delphi进行OpenGL编程学习心得 (1)
下一篇: DELPHI编程实现3DS的动画播放

1 2 3 下一页

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:用Delphi为窗体的系统菜单中添加选项 (1)

下一篇:Delphi编程创建和删除文件夹 (1)