本文整理匯總了VB.NET中System.Threading.SemaphoreSlim類的典型用法代碼示例。如果您正苦於以下問題:VB.NET SemaphoreSlim類的具體用法?VB.NET SemaphoreSlim怎麽用?VB.NET SemaphoreSlim使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了SemaphoreSlim類的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的VB.NET代碼示例。
示例1: Example
' 導入命名空間
Imports System.Threading
Imports System.Threading.Tasks
Module Example
Private semaphore As SemaphoreSlim
' A padding interval to make the output more orderly.
Private padding As Integer
Public Sub Main()
' Create the semaphore.
semaphore = New SemaphoreSlim(0, 3)
Console.WriteLine("{0} tasks can enter the semaphore.",
semaphore.CurrentCount)
Dim tasks(4) As Task
' Create and start five numbered tasks.
For i As Integer = 0 To 4
tasks(i) = Task.Run(
Sub()
' Each task begins by requesting the semaphore.
Console.WriteLine("Task {0} begins and waits for the semaphore.",
Task.CurrentId)
semaphore.Wait()
Interlocked.Add(padding, 100)
Console.WriteLine("Task {0} enters the semaphore.", Task.CurrentId)
' The task just sleeps for 1+ seconds.
Thread.Sleep(1000 + padding)
Console.WriteLine("Task {0} releases the semaphore previous count: {1}.",
Task.CurrentId, semaphore.Release())
End Sub )
Next
' Wait for half a second, to allow all the tasks to start and block.
Thread.Sleep(500)
' Restore the semaphore count to its maximum value.
Console.Write("Main thread calls Release(3) --> ")
semaphore.Release(3)
Console.WriteLine("{0} tasks can enter the semaphore.",
semaphore.CurrentCount)
' Main thread waits for the tasks to complete.
Task.WaitAll(tasks)
Console.WriteLine("Main thread exits.")
End Sub
End Module
輸出:
0 tasks can enter the semaphore. Task 1 begins and waits for the semaphore. Task 5 begins and waits for the semaphore. Task 2 begins and waits for the semaphore. Task 4 begins and waits for the semaphore. Task 3 begins and waits for the semaphore. Main thread calls Release(3) --> 3 tasks can enter the semaphore. Task 4 enters the semaphore. Task 1 enters the semaphore. Task 3 enters the semaphore. Task 4 releases the semaphore; previous count: 0. Task 2 enters the semaphore. Task 1 releases the semaphore; previous count: 0. Task 3 releases the semaphore; previous count: 0. Task 5 enters the semaphore. Task 2 releases the semaphore; previous count: 1. Task 5 releases the semaphore; previous count: 2. Main thread exits.