Allows statements to be synchronized on a single expression.
SyncLock expression ...[ block ] End SyncLock
Parts
-
expression
- Required. A unique collection of operators and values that yield a single result. block
- Optional. The statements that will execute in sequence. End SyncLock
- Terminates a SyncLock procedure.
Remarks
The SyncLock statement ensures that multiple threads do not execute the same statements at the same time. When the thread reaches the SyncLock block, it evaluates the expression and maintains this exclusivity until it has a lock on the object that is returned by the expression. This prevents an expression from changing values during the running of several threads, which can give unexpected results from your code.
Note The type of the expression in a SyncLock statement must be a reference type, such as a class, a module, an interface, array or delegate.
Example
Class Cache Private Shared Sub Add(ByVal x As Object) SyncLock GetType(Cache) End SyncLock End Sub Private Shared Sub Remove(ByVal x As Object) SyncLock GetType(Cache) End SyncLock End Sub End Class