首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

VB.NET并行与分布式编程(七)-线程池[1]

2012-08-28 
VB.NET并行与分布式编程(7)-线程池[1]一、CLR线程池管理2类线程1、普通的工作线程1)使用QueuUserWorkItem2)T

VB.NET并行与分布式编程(7)-线程池[1]

一、CLR线程池管理2类线程

1、普通的工作线程

1)使用QueuUserWorkItem

2)ThreadPool.QueueUserWorkItem 方法

方法排入队列以便执行。此方法在有线程池线程变得可用时执行

QueueUserWorkItem(WaitCallback)? 将方法排入队列以便执行。此方法在有线程池线程变得可用时执行。?
???? QueueUserWorkItem(WaitCallback, Object)? 将方法排入队列以便执行,并指定包含该方法所用数据的对象。此方法在有线程池线程变得可用时执行。?
2、I/O完成

1)使用BindHandle

2)
a)这个方法过时,可使用b方法

操作系统句柄绑定到ThreadPool。

<ObsoleteAttribute("ThreadPool.BindHandle(IntPtr) has been deprecated.? Please use ThreadPool.BindHandle(SafeHandle) instead.",? _
?False)> _
<SecurityPermissionAttribute(SecurityAction.Demand, Flags := SecurityPermissionFlag.UnmanagedCode)> _
Public Shared Function BindHandle ( _
?osHandle As IntPtr _
) As Boolean
参数
osHandle
类型:System.IntPtr
持有句柄的 IntPtr。 在非托管端必须为重叠 I/O 打开该句柄。

返回值
类型:System.Boolean
如果绑定了句柄,则为 true;否则为 false。

?

b)ThreadPool.BindHandle 方法 (SafeHandle)
将操作系统句柄绑定到 ThreadPool。

?

?'声明
<SecurityPermissionAttribute(SecurityAction.Demand, Flags := SecurityPermissionFlag.UnmanagedCode)> _
Public Shared Function BindHandle ( _
?osHandle As SafeHandle _
) As Boolean
参数
osHandle
类型:System.Runtime.InteropServices.SafeHandle
保存操作系统句柄的 SafeHandle。 在非托管端必须为重叠 I/O 打开该句柄。

返回值
类型:System.Boolean
如果绑定了句柄,则为 true;否则为 false。

?

osHandle 参数应该为 SafeFileHandle,它派生自抽象类 SafeHandle。

?二、线程池中的线程数量管理

1、ThreadPool.SetMaxThreads 方法

1)设置可以同时处于活动状态的线程池的请求数目。 所有大于此数目的请求将保持排队状态,直到线程池线程变为可用。

?2)

声明
<SecurityPermissionAttribute(SecurityAction.Demand, ControlThread := True)> _
Public Shared Function SetMaxThreads ( _
?workerThreads As Integer, _
?completionPortThreads As Integer _
) As Boolean
参数
workerThreads
类型:System.Int32
线程池中辅助线程的最大数目。

completionPortThreads
类型:System.Int32
线程池中异步 I/O 线程的最大数目。

返回值
类型:System.Boolean
如果更改成功,则为 true;否则为 false。

2、其它方法GetAvailableThreads检索由GetMaxThreads方法返回的最大线程池线程数和当前活动线程数之间的差值。GetMaxThreads检索可以同时处于活动状态的线程池请求的数目。所有大于此数目的请求将保持排队状态,直到线程池线程变为可用。GetMinThreads发出新的请求时,在切换到管理线程创建和销毁的算法之前检索线程池按需创建的线程的最小数量。?SetMaxThreads? 设置可以同时处于活动状态的线程池的请求数目。 所有大于此数目的请求将保持排队状态,直到线程池线程变为可用。?
?? SetMinThreads? 发出新的请求时,在切换到管理线程创建和销毁的算法之前设置线程池按需创建的线程的最小数量。?

热点排行