`
deepfuture
  • 浏览: 4333566 次
  • 性别: Icon_minigender_1
  • 来自: 湛江
博客专栏
073ec2a9-85b7-3ebf-a3bb-c6361e6c6f64
SQLite源码剖析
浏览量:79428
1591c4b8-62f1-3d3e-9551-25c77465da96
WIN32汇编语言学习应用...
浏览量:68376
F5390db6-59dd-338f-ba18-4e93943ff06a
神奇的perl
浏览量:101498
Dac44363-8a80-3836-99aa-f7b7780fa6e2
lucene等搜索引擎解析...
浏览量:281206
Ec49a563-4109-3c69-9c83-8f6d068ba113
深入lucene3.5源码...
浏览量:14608
9b99bfc2-19c2-3346-9100-7f8879c731ce
VB.NET并行与分布式编...
浏览量:65559
B1db2af3-06b3-35bb-ac08-59ff2d1324b4
silverlight 5...
浏览量:31320
4a56b548-ab3d-35af-a984-e0781d142c23
算法下午茶系列
浏览量:45206
社区版块
存档分类
最新评论

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

 
阅读更多

在此,我们仅以GetAvailableThreads为例:

GetAvailableThreads 返回时,workerThreads 指定的变量包含可以启动的其他辅助线程的数目,而 completionPortThreads 指定的变量包含可以启动的其他异步 I/O 线程的数目

代码如下:

Imports System
Imports System.Threading
Imports System.Runtime.InteropServices
Imports System.Diagnostics
Imports System.Diagnostics.ThreadState


Module Module1
    Dim jg As Long = 0
    Public Class TaskInfo
        Public Handle As RegisteredWaitHandle = Nothing
        Public OtherInfo As String = "default"
        Public ev As AutoResetEvent
    End Class


    <MTAThread()> _
    Sub Main()








        '定义AutoResetEvent和RegisteredWaitHandle对象
        Dim myHandle As RegisteredWaitHandle = Nothing


        Dim ti As New TaskInfo()
        ti.ev = New AutoResetEvent(False)
        ti.OtherInfo = "deepfuture test"
        '注册等待,等待线程的任务就是定时取计算结果,如果没有计算完成,就继续等待
        ti.Handle = ThreadPool.RegisterWaitForSingleObject( _
           ti.ev, _
           New WaitOrTimerCallback(AddressOf mythreadrun), _
           ti, _
           100, _
           False _
       )
        Console.Write("{0},开始执行线程,主线程{1}正在计算结果", Now.ToLongTimeString, Thread.CurrentThread.ManagedThreadId)
        '等待并执行其它代码
        For mynum = 1 To 100
            jg += mynum
            Thread.Sleep(10)
            Console.WriteLine("主线程{0}正在运行.....当前计算结果为{1}", Now.ToLongTimeString, jg)
        Next
        Console.WriteLine("主线程  " & Now.ToLongTimeString & "线程计算完毕!")
        '设置为终止状态,触发回调
        ti.ev.Set()
        Thread.Sleep(20)


    End Sub
    Public Sub mythreadrun(ByVal state As Object, ByVal timedOut As Boolean)
        '本线程的任务是的计算完成后显示结果,没计算完成时,做其它工作,
        '在这里其他工作就是显示一个"."
        Dim ti As TaskInfo = CType(state, TaskInfo)
        Dim workerThreads As Integer
        Dim portThreads As Integer
        If timedOut Then
            '时间到,仍没计算完毕,为非终止状态 
            Console.WriteLine("等待时间到,计算没有完毕,继续等待...")
            ThreadPool.GetAvailableThreads(workerThreads, portThreads)
            Console.WriteLine("目前可以启动的工作线程的数目{0},目前可以启动的异步IO线程的数目{1}", workerThreads, portThreads)
        Else
            If Not ti.Handle Is Nothing Then
                '已经终止
                ti.Handle.Unregister(Nothing)
            End If
            Console.WriteLine("主线程{0}运行完成.....读取最终计算结果为{1}", Now.ToLongTimeString, jg)
        End If
    End Sub
End Module

 

 

 

  • 大小: 99 KB
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics