Multithreading and Synchronization in .NET - PowerPoint PPT Presentation

About This Presentation
Title:

Multithreading and Synchronization in .NET

Description:

?????? ???????? ?? ?????? ??????? ?? ?????? ? .NET ... Time Slice. Thread. Thread. Thread. Thread. Thread. Running Queue. Return to Queue. Pull From Queue ... – PowerPoint PPT presentation

Number of Views:1208
Avg rating:3.0/5.0
Slides: 187
Provided by: mihails5
Category:

less

Transcript and Presenter's Notes

Title: Multithreading and Synchronization in .NET


1
(No Transcript)
2
???????????? ???????????? ? ?????????????
???????????? ?? .NET Framework
http//www.nakov.com/dotnet-project/
?????? ??????? ????????? ???????, Sciant Inc.
www.sciant.com Microsoft Student
Consultant www.fmi.uni-sofia.bg/microsoft/
3
?????????? ??????
  • ?????? ???????? ?? .NET Framework ? CLR
  • ?????? ???????? ?? ?????? ??????? ?? ?????? ?
    .NET (Common Type System)
  • ?????? ???????? ?? ????? C
  • ?????? ???????? ?? ??????????? ???????
  • ????????

4
??????????
  • ??????????????
  • ?????
  • ?????????????
  • ?????????? ??????????
  • ????????? ??? ????? ???????? ? ?????? ?????????
    ??? ???????? ???????? ?? ???????????? ?? ??????

5
?????????????? ??????????
  • ??????????????
  • ????????? ???? ???????????????
  • ??????? ?? ????????????????
  • ????????? ??????? ? ?????
  • ??????? ? ???????
  • ????? ??????????
  • ???? ?? ?????? ????????
  • ?????????????? ??????
  • ????????????? ?? ??????????????
  • Application Domains
  • ?????
  • ?????????????
  • ?????????? ??????????

6
?????????
  • ??? ??????, ? ????? ?????? ?????????? ?????? ??
    ??????? ????????????? ???????? ??? ?? ???? ??
    ??????????????? ?? ??????
  • ??? ??????, ? ????? ?????? ?????????? ?????? ??
    ???????? ???????? ?? ????? ????
  • ????? ? ?????????, ????? ?? ????????? ???????
    ???????? ?? ?? ????????? ????????????

7
??????? ?? ????????????????
  • Performance ?? ???????? ? ??????? ?????????
    ?????? ??-?????
  • Responsiveness ????????? ???????? ??????????
    ????? ??? ???????????? ??????
  • Throughput ??????????? ?? ??????????????????
  • ?????? ??? ???????????? ?????????? ?? ???????
    ???? ????????????
  • ?????????? ?? ????? ??????????? ????????????

8
???????????? 1
  • ???? ? ????? ??????????????

9
????????? ??????? ? ?????
  • ???????? ???????????? ???????????? ?? ?????, ????
    ? ???? ?? ????????????
  • OS ????????? ??????? (process), ?? ??
    ????????????? ?????????? ??????????
  • ??????? (thread) ? ????????? ???????, ?? ????? OS
    ???? ?? ?????? ?????????? ?????
  • ? ???? ?????? ?????????? ?????? ?? ?????????? ??
    ??????? ?????
  • ? ???? ?????? ??? ???? ???? ?????

10
?????? vs. ?????
  • ???????
  • ???????? ???? (stack)
  • ?????????
  • exception handlers
  • ???????
  • ????????? ?? ????????? ???? ?? ???? ?? ?????????
    ?? ????? ? ?????
  • ??????? ? ???? ?????? ???????? ???????
    (???????????? ? ???????) ?? ???? ??????
  • ????????? ???????? ?????????? ???, ? ??????? ??
    ??????????

11
????? ????????? ????????
  • ???????????? ?? ??????? ?????
  • ??????? ??????????? ?? ?????????? ?? ???????
    ?????? ????????????
  • ????????? ???????, ???? ????? ???? ????? ?????
    ????????? ? ????? ??????
  • ????????
  • ???????????? ???? ?? ??????? ????? ?
    ????????????????? ???????? ?????? ?? ???????
    ????? ?? ???????
  • ?? ???? ??????????? ??? ???????????? ???????? ??
    ?????? ????????? ?? ?????? ???????? ??

12
???? ?? ?????? ????????
  • ??????, ? ????? ? ?????? ?? ?? ????????? ?????
  • ?????????? ?? ????? ??????????? ????????????,
    ???????? Web ??????
  • ??????????? ???? ????? (sockets)
  • ?????????? ?? ????????????? ????????
  • ??????????? ?? ???????? ?? ?????????
  • ?? ?? ???? ??????????????? ????????? ?? ????????
    ?? ???????? ?? ????????????? ??????, ?????? ??
    ????? ???? ?? ???????? ????? ??????

13
?????????????? ???????????? ? ????????????
  • ???????????? ?????????????? (cooperative
    multitasking)
  • ??????? ???? ?????? ????? ?????????? ????? ? ?
    ??????????
  • ????? ?? ?? ????????? ???? ??? ? ???????? ???
    ???? ?? ??????? ??????
  • ???????????? ?????????????? (preemptive
    multitasking)
  • ????????????? (task scheduler) ??????
    ????????????? ??????? ?????????? ?????
  • ??? ???????? ???? ? ??????????, ??????? ?? ?????
    ?? ?????????

14
?????????????? ???????????? ? ????????????
  • ??? ?????????????? ??????????????
  • ???? ????? ???? ????? ????? ?? ????? ?????????
  • ?????? ??? ?????????? ????? ????? ?? ?????
    ??????????? ?????
  • ????? ??????? ????????? ?????????? ???????
  • ????? ? ????? ????????? ?? ?????? ????????????
    ?????? ??????? ? ??-????? ?????????

15
????????????? ?? ??????????????
Apartment
Apartment
Process
Global Data
Global Data
Global Data
Thread
Thread
Thread
Thread
Instruction
Instruction
Instruction
Instruction
Instruction
Instruction
Instruction
Instruction
Apartment Threading
Free Threading
16
Application Domain
  • .NET Framework ?????? ??? ???? ???? ?? ??????????
    ????? ????? ? ?????? Application Domain
  • AppDomain-?? ???? ????????? ????????
  • ??? ????????? ?????????? ? ?????????, ??? ???? ?
    ????????????? ?? ???? OS
  • ??????????
  • ????????? ????????????????
  • ???? ?? ???????? ???? ??? ???????
  • ?????? ?/? ????? ??? proxy
  • ???????? type checking
  • System.AppDomain

17
System.AppDomain
AppDomain 1
AppDomain 2
AppDomain 3
Global Data
Global Data
Thread
Thread
Instruction
Instruction
AppDomain 4
Thread
Thread
Global Data
Instruction
Instruction
18
????? ??????????
  • ??????????????
  • ?????
  • ??? ??????? ???????
  • ????? ?? ???????
  • ??-????? ???????
  • ?????????
  • ?????????
  • Thread Local Storage
  • Thread-Relative Static Fields
  • ????????????
  • ??????????
  • ?????????? ?? ?????
  • ?????????????
  • ?????????? ??????????

19
??? ?????? ????????????????
Time Slice
Running Queue
Instruction
Thread
Pull From Queue
Instruction
Thread
Instruction
Thread
Instruction
Thread
Interrupt
Thread
Return to Queue
20
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
21
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
22
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
23
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
24
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
25
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
26
????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Start() t2.Start()
27
????? ??????
//???????? Thread1job(1) Thread1job(2) Thread2
job(1) Thread1job(3) ... ... Thread1job(53) Thre
ad2job(46) Thread2job(47) Thread1job(54) ... ..
. Thread1job(97) Thread2job(99) Thread1job(98)
Thread1job(99)
28
???????????? 2
  • ????? ????? ??????

29
?????? ????? ?? ???????
Start()
IsAlive
All Done
Suspend()
Sleep()
WaitX()
Join()
Abort()
WaitSleepJoin
WaitSleepJoin
WaitSleepJoin
Stopped
Suspended
Interrupt()
Interrupt()
Thread Stopped
Aimed Thread Destroyed
Resume()
Expire time
Notified
30
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart )
  • ??????? ?????????
  • ?????? ?? ??????? ? ?????, ????? ?? ?? ???????
    ??? ??????????
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

31
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • ???????? ???????? ????? ?? ???????? ????
    ??????????? (? ???????????)
  • ??????? ?? ???? ?? ?????? ?????
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

32
????? ?????? ?? Sleep()
Instruction
Sleep Queue
Running Queue
T
Thread
Instruction
T
Thread
from Queue
T
Instruction
Thread
To Sleep Queue
T
Instruction
Thread
Sleep()
T
Thread
Clock Interrupt
33
?????????? ?? ?????
using System using System.Threading public
class ThreadSleep public static Thread
worker public static Thread worker2 public
static void Main() Console.WriteLine("Ente
ring void Main!") worker new Thread(new
ThreadStart(Counter)) worker2 new
Thread(new ThreadStart(Counter2))
worker.Start() worker2.Start()
Console.WriteLine("Exiting void Main!")
(???????? ??????????)
34
?????????? ?? ?????
public static void Counter()
Console.WriteLine("Entering Counter")
for(int i 1 i lt 50 i)
Console.Write(i " ") if(i 10)
Thread.Sleep(1000) Console.WriteLine("\
nExiting Counter") public static void
Counter2() Console.WriteLine("Entering
Counter2") for(int i 51 i lt 100 i)
Console.Write(i " ") if( i
70 ) Thread.Sleep(5000)
Console.WriteLine(\nExiting Counter2")
35
???????????? 3
  • ?????????? ?? Thread.Sleep()

36
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • ??? ??????? ? ? ????????? Running, ?
    ????????????? ???????? (suspend)
  • ??? ? ?????????????, ?? ?? ?????? ????
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

37
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • ????????? ?????, ????? ? ???? ?????????????
    (suspended)
  • ??? ??????? ??????, ?? ????? ????
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

38
???????????? 4
  • ?????????? ?? Suspend() ? Resume()

39
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • true, ??? ? ?????????? ? ?? ? ?????? ??????????
    ??? ??????????
  • ?????? ?????????? ???? ThreadState
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

40
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • ?????? ???? (foreground) ? ????? ?????
    (background)
  • ???????? ?? ?????/?????????
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

41
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • ???????? ?? ?????/?????????
  • true, ??? ??????? ?????????? ?? managed thread
    pool, ????? false
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

42
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • ????? ????? ? .NET Framework ???? ?? ??? ???
  • ???????? ?? ?????/????????? ?? ?????
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

43
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • Lowest, BelowNormal, Normal (?? ????????????),
    AboveNormal, Highest
  • ???????? ?? ???????/?????????
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()

44
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • ??????? ??????????? ?? ??????? ?????? ?? ????
    ???? ??????? ??????
  • ???????? ???? ?? ?????????
  • Abort()
  • Interrupt()
  • Join()
  • Start()

45
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • ?????????? ????? ???????
  • ?????? ThreadAbortException ? ?????????? ?????
  • Interrupt()
  • Join()
  • Start()

46
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • ??????? ????? ??? ? ? ????????? WaitSleepJoin,
    ????? ?? ????? ????
  • ?????? ThreadInterruptedException
  • Join()
  • Start()

47
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • ??????????? ????? ???????, ?????? ??????????
    ????????
  • ???? ?? ?? ????? ??????? (timeout)
  • Start()

48
???????????? 5
  • ?????????? ?? Thread.Join()

49
??-??????? ??????? ?? Thread
  • public Thread( ThreadStart start)
  • Sleep()
  • Suspend()
  • Resume()
  • IsAlive
  • IsBackground
  • IsThreadPoolThread
  • Name
  • Priority
  • ThreadState
  • Abort()
  • Interrupt()
  • Join()
  • Start()
  • ???????? ?????????? ?????
  • ?????????? ?? ? ????????? (????? ????????????
    ???????)

50
????????? ?? ?????
  • ???????? ????????????? ?? ?????????????? ????????
    ????????????? ???????? "?????????"
  • ??????????? ?????? ????? ????? ? ??????? (?????
    ????? ?? ? ?? ??????)
  • ????? ? ?? ???????????? (task scheduler)
  • ??????????? ? .NET Framework
  • ???????? ?????????
  • Lowest, BelowNormal, Normal (?? ????????????),
    AboveNormal, Highest
  • ? Win32 ??? ? ????????? RealTime
  • OS ?? ? ?????? ?? ?? ?????????? ? ?????????? ??
    ???????, ?? ?????????? ?? ?????

51
????????? ??????
class FirstThread public void DoTask1()
for( int i0 ilt100 i )
Console.WriteLine("Thread1job(0)",i)
public void DoTask2() for( int i0 ilt100
i ) Console.WriteLine("Thread2job(0)",i
) class Starter static void
Main(string args) FirstThread ft new
FirstThread() Thread t1 new Thread(
new ThreadStart(ft.DoTask1)) Thread t2 new
Thread( new ThreadStart(ft.DoTask2))
t1.Priority ThreadPriority.Highest
t1.Start() t2.Start()
52
?????????
???????? Thread1job(1) Thread1job(2) Thread2jo
b(1) Thread1job(3) ... ... Thread1job(97) Thread
1job(98) Thread2job(85) Thread1job(99) Thread2
job(86) ... ... Thread2job(97) Thread2job(98) Th
read2job(99)
53
ThreadState
  • ????? ????? ??? ????? ???? ?????? ? ? ????? ??
    ??????????? ?? ???????????? ThreadState
  • ??????? ?? ?? ???? ? ??????? ?????????
    ????????????
  • ???????????? ??? ??????? FlagsAttribute
  • ???? ????????? ???????? ??????????? ??
    ??????????? ?
  • if ((state (Unstarted Stopped)) 0)
  • // implies Running
  • ?????? ?? ??????? ????? ? ? ????????? Unstarted
  • ?????? ???? ?????? ?? ?? ?????? Start()

54
??????????? ? ThreadState
  • Aborted(256)
  • ??????? ? ?????? Abort()
  • ??????? ? ? ????????? Stopped, ???????????? ?
    Aborted
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

55
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • ??????? Abort() ? ??? ???????
  • ??? ?? ? ???????? ThreadAbortException, ????? ??
    ?? ????? ?? ? ????????
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

56
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • ??????? ? ??? ????? ?????
  • ??????? ?? ??? ?????????? Thread.IsBackground
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

57
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • ??????? ? ?????????? ? ?? ? ?????????
  • ???? ?????? ?????????? ThreadAbortedException
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

58
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • ??????? ? ?????????? ?? ?????? ?? Abort() ???
  • ?????????? ? ???????? ?? ??????????
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

59
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • ???????? ? ???? ?? ??????? ?? ???? ??????
  • ???? ?? ???????? ????????
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

60
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • ??????? ? ???? ?????????????
  • ?????????? ????? ???? ? ??????? Suspend(), ????
    Resume() ? ??????????
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)

61
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • ??????? ? ?????? Suspend()
  • ??????? ?? ?? ?????? ?? ???????? ?????????, ?? ??
    ?? ???????????
  • Unstarted(8)
  • WaitSleepJoin(32)

62
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • ?? ? ??????????, ???????? ?? ??? Start()
  • ???? ???? ?? ???????? ??????? ?????? ?????? ??
    ???? ??? ?? ? ? ???? ?????????
  • WaitSleepJoin(32)

63
??????????? ? ThreadState
  • Aborted(256)
  • AbortRequested(128)
  • Background(4)
  • Running(0)
  • Stopped(16)
  • StopRequested(1)
  • Suspended(64)
  • SuspendRequested(2)
  • Unstarted(8)
  • WaitSleepJoin(32)
  • ??????? ? ?????????
  • ????? ? ???? ?? ???????? Thread.Wait(),
    Thread.Sleep(), Thread.Join()

64
???????????? ?? ?????
  • ?? ?? ?? ???? ???? ?????, ?? ???????? ???????
    Thread.Abort()
  • Thread.Abort() ?????? ??????????? ??????????
    ThreadAbortedException
  • ?????? ThreadStateException, ??? ??????? ???? ?
    ??????????
  • ?????????? ?? catch ? finally ?? ????????????
    ?????
  • Thread.ResetAbort() ?? ????????? ?? CLR ?? ??????
    ???????????? ??????
  • Unmanaged code ?????????

65
???????????? ?? ????? ??????
public class BackgroundThread public void
DoBackgroundJob() try // ???????
???????? ??????? ??????
catch(ThreadInterruptedException)
MessageBox.Show("Thread interrupted.")
catch(ThreadAbortException)
MessageBox.Show("Thread aborted.")
finally MessageBox.Show("Finally
block.") MessageBox.Show("After
finally block.") (???????? ??????????)
66
???????????? ?? ????? ??????
public class InterruptAbortDemo private
Thread mBgThread public InterruptAbortDemo()
bg new BackgroundThread() mBgThread
new Thread(new ThreadStart(bg.DoBackground
Job)) mBgThread.IsBackground true
mBgThread.Start() private void
btnSuspend_Click(...) mBgThread.Suspend()
(???????? ??????????)
67
???????????? ?? ????? ??????
  • private void btnResume_Click(...)
  • mBgThread.Resume()
  • private void btnInterrupt_Click(...)
  • mBgThread.Interrupt()
  • private void btnAbort_Click(...)
  • mBgThread.Abort()

68
???????????? 6
  • ?????????? ?? Priority, State, Suspend, Resume,
    Interrupt ? Abort

69
Thread Local Storage
  • ?????????, ? ????? ??????? ????? ?? ??????????
    ?????
  • ????? ?? ???? ?? ??????? ??????? ?? ????? ?????
  • Thread.AllocateNamedDataSlot
  • ???????? ?????????
  • ???????? ???????? ?????
  • Thread.AllocateDataSlot
  • ???? ???, ???? reference
  • ???????? ??? ??????? ??? ?? ???? ? ???? ?????
    ????????? ??? ????

70
Thread Local Storage ??????
class Threads public void CreateDataThread()
LocalDataStoreSlot slot
Thread.AllocateNamedDataSlot("mySlot")
//????????? ????? ????? ? NamedSlot
Thread.SetData(slot ,"IMPORTANT DATA") //
Suspend-???? Thread.CurrentThread.Suspend()
// ????????? ?????? ??????? object myData
Thread.GetData("mySlot") public void
ReadDataThread() LocalDataStoreSlot slot
Thread.GetNamedDataSlot("mySlot") //
???????? ?? ?? ???????? ????????????
Thread.SetData(slot, "BAD DATA") (????????
??????????)
71
Thread Local Storage ??????
class TLSDemo static void Main(string
args) Threads threads new Threads()
Thread createData new Thread( new
ThreadStart(threads.createDataThread) )
createData.Start() Thread readData new
Thread( new ThreadStart(threads.readDataThre
ad) ) readData.Start()
readData.Join() createData.Resume()
72
???????????? 7
  • ThreadLocalStorage

73
Thread-Relative Static Fields
  • ???? ???????? ??????????, ?? ??? ?? ????
    ????????? ?? ????? ????? ?? ??????????
  • ????????? ?? ???? ???????? ??????????, ?? ?
    ???????? ThreadStatic
  • ????? ?????, ????? ? ???????? ?????? ?? ?
    ????????????
  • ?? ?????????? ?? ???????????? ?? ????????????
    ?????? ??????????, ?????? ??? ?? ????????? ?
    ???????????? ?????!

74
Thread-Relative Static Fields ??????
class ThreadStatic static void Main(string
args) for( int i0 ilt10 i ) new
Thread(new ThreadStart(new
MyThread().DoTask)).Start() class
MyThread ThreadStatic public static int
abc public MyThread() abc42 // This
runs in the main app. thread public void
DoTask() abc Console.WriteLine("abc
0", abc)
75
???????????? 8
  • ?????????? ?? Thread Static ????

76
?????????? ?? ???????
  • ?????? ????????????? ?? ?????????????? ???????
    ???????
  • ????? ???????? ? ?? ?? ??????????? ? ????????????
    ?? ?????
  • ???????? ? ?????????? ?? ???????? ?????? ???????
    ?? ???????????? ?? ??????? ????????? ??
    ???????????? ??
  • ?????????? ?? ?? ?????????? ThreadPool ?????? ?
    ????????
  • ????????? ?? ????? ????? ? ??????

77
????????? ????? ????????
  • Race condition
  • ??? ????? ???????????? ????????? ???? ? ????
    ?????
  • ???????????? ?????????
  • ???????? ??? ????? ???????????? ?????????? i ??
    ???? ?????????? i
  • Deadlock
  • ?????????, ? ????? ??? ????? ?? ????? ??????? ??
    ????????????? ?? ??????? ????? ???????
  • A ????? ??????? X, B ????? ??????? Y ? ???? ?? X,
    ? A ??????? ?? ???? ?? Y

78
Race Condition ??????
  • using System
  • using System.Threading
  • class Account
  • public int mBalance
  • public void Withdraw100()
  • int oldBalance mBalance
  • Console.WriteLine("Withdrawing 100...")
  • Thread.Sleep(100)
  • int newBalance oldBalance - 100
  • mBalance newBalance
  • (???????? ??????????)

79
Race Condition ??????
static void Main(string args) Account acc
new Account() acc.mBalance 500
Console.WriteLine("Account balance 0",
acc.mBalance) Thread user1 new Thread(
new ThreadStart(acc.Withdraw100) )
Thread user2 new Thread( new
ThreadStart(acc.Withdraw100) )
user1.Start() user2.Start()
user1.Join() user2.Join()
Console.WriteLine("Account balance 0",
acc.mBalance)
80
???????????? 9
  • ?????????? ?? ?????

81
????????????? ??????????
  • ??????????????
  • ?????
  • ?????????????
  • ???-??????? ???????
  • ????????? ?? ?????????????
  • Synchronized Contexts
  • Synchronized code regions
  • MethodImplAttribute
  • Unmanaged Synchronization WaitHandle
  • ????????? ???????
  • ?????????? ???????????????? ????????
  • ThreadPool
  • ?????????? ??????????

82
???-??????? ???????
  • ???-????? ????????? ??? ????????? ????? ?
    ???????????? ????? ? ??????? ?? ????????? ?????
  • ?????????? ??
  • ?? ?? ?????????? ??????? ? ????????? ? ?????????
    ?? ??????
  • ???? ?????? ?? ?? ?? ???????? ????? ?????
  • ?????? ???? ? ??????????, .NET Framework,
    ?????????? ????????? ?? ????????????? ?? ???????
    ?? ?????

83
????????? ?? ?????????????
  • ?????????????? ????????? (Synchronized Contexts)
  • ?????????????? ?????? ??? (Synchronized code
    regions)
  • MethodImplAttribute (MethodImplOptions.Synchroniz
    ed) ??? ??????????????? ?? ?????
  • Unmanaged ?????????????
  • ??????? ?? ????, ????? ????????? (custom)
    ????????????? ? ?????? ?? OS

84
Synchronized Contexts
  • ???????? ?? SynchronizationAttribute ?? ??????,
    ??????????? ContextBoundObject
  • ??????, ????? ???????? ? ???? ????????
  • ?????? ????? ? ???? ???????? ????????? ????????
    ?? ????????? ?? ?????? ?????? ??????????????
  • ?????????? ??????? ?? ?? ??????????
  • ?? ?? ???????? ?????????????? ?? ??????????
    ???????? ?? ??? ???????????? ??? ????

85
Synchronized Contexts ??????
SynchronizationAttribute class CBO
ContextBoundObject public void
DoSomeTask1() Console.WriteLine("Job
1 started.") Thread.Sleep(2000)
Console.WriteLine("Job1 finished.\n")
public void DoSomeTask2()
Console.WriteLine("Job2 started.")
Thread.Sleep(1500) Console.WriteLine("Job
2 finished.\n") (???????? ??????????)
86
Synchronized Contexts ??????
static void Main() CBO syncClass new
CBO() Console.WriteLine("Started 6
threads\n" "3 doing Job1 and 3 doing
Job2.\n\n") for (int i0 ilt6 i)
Thread t if (i20) t
new Thread( new ThreadStart(
syncClass.DoSomeTask1) ) else
t new Thread( new ThreadStart(
syncClass.DoSomeTask2) ) t.Start()

87
???????????? 10
  • ????????????? ???? ContextBoundObject

88
???????? ??????
lock (obj) //..code..
Monitor.Enter(obj) try /..code../ finally
Monitor.Exit(obj)
  • ??????????? (managed) ??????????
  • ???? ?? ?? ?????? ? ?? ???????? ??????? ??
    ?????????
  • ???????????? ?? ???????????? ???? ??????, ????? ?
    ??????????
  • ?????? ?? ???????? ??????
  • Monitor.TryEnter()

89
???????? ?????? ??????
public class MonitorEnterExit private int
mCounter public void CriticalSection()
Monitor.Enter(this) mCounter 0 try
for(int i 1 i lt 5 i)
Console.Write(mCounter)
Thread.Sleep(1000) finally
Monitor.Exit(this) (????????
??????????)
90
???????? ?????? ??????
static void Main()
MonitorEnterExit mee new MonitorEnterExit()
Thread thread1 new Thread(new
ThreadStart(mee.CriticalSection))
thread1.Start( ) Thread thread2 new
Thread(new ThreadStart(mee.CriticalSection))
thread2.Start( ) //
???????? 1234512345 // ???????? ???
????????????? 1123456789
91
???????????? 11
  • ?????? ? ???????? ??????

92
??????? ????? ??????
  • Monitor.Wait(object)
  • ??????????? ???????? ?? ?????? ? ??????? ???????
    ?????? ?? ?? ??????
  • ???? ?? ?? ?????? Timeout
  • ??????? ?? ??????? ?? waiting queue
  • ???? Pulse(object), PulseAll(object)
  • Monitor.Pulse(object)
  • ??????? ????????? ? ready queue(??? ????? ??
    ????? ???????? ?? ?????)
  • ???? ?? ???? ?? ??????? ?????????? ?? ???????? ??
    ?????? (?? ???????? ??????)
  • Monitor.PulseAll(object)

93
Wait() ? Pulse() ??????
  • ????? ??? ?????, ????? ????????? ??????????
    ??????? ??????
  • ?????? ?????? ????? ????, ??????? ? ??????? ?
    ?????????

public class WaitPulse private object mSync
private string mName public WaitPulse(string
aName, object aSync) mName aName
mSync aSync (???????? ??????????)
94
Wait() ? Pulse() ??????
public void DoJob() lock (mSync)
Monitor.Pulse(mSync) for(int i 1 i
lt 3 i) Console.WriteLine("0
Puls?", mName) Monitor.Pulse(mSync)
Console.WriteLine("0 Wait", mName)
Monitor.Wait(mSync) Console.WriteLine("
0 WokeUp", mName) Thread.Sleep(1000)
(???????? ??????????)
95
Wait() ? Pulse() ??????
public class WaitPulseDemo public static void
Main(String args) object sync new
object() WaitPulse wp1 new WaitPulse(
"WaitPulse1", sync) Thread thread1 new
Thread( new ThreadStart(wp1.DoJob))
thread1.Start() WaitPulse wp2 new
WaitPulse( "WaitPulse2", sync) Thread
thread2 new Thread( new
ThreadStart(wp2.DoJob)) thread2.Start()

96
???????????? 12
  • ?????? ? Wait() ? Pulse()

97
MethodImplAttribute (MethodImplOptions.Synchroniz
ed)
  • ??????? ?? lock ????? ??? ?????
  • ???? ?? ???????????? ? static ???????

MethodImpl(MethodImplOptions.Synchronized)
public void DoSomeTask1() Console.WriteLine("
job1 started") for (int i0 ilt1000000000
i) Math.Sqrt(i) Console.WriteLine("Job1
done.\n")
98
Unmanaged Synchronization
  • WaitHandle
  • Unmanaged ????????? ?? ?????????????
  • ???????? ?????? ?? ????????????? ??????? ??
    ????????? ?? ???????
  • ?????????? ??????????? ????? ???? ?? CLR
    WaitAll(), WaitAny()
  • ?? ?? ?????????? ?? ? managed
  • ??? ??????? ??????????
  • Mutex
  • AutoResetEvent
  • ManualResetEvent

99
?????? WaitHandle
  • ???????? ?????? ?? ????????? ?? ????????? ??
    ???????
  • ????????? signaled, nonsignaled
  • WaitAll() (static)
  • ??????? ?????? ?? ?????? ??????? ?? ?????
  • WaitAny() (static)
  • ??????? ??????? ???????? ??????
  • WaitOne()
  • ??????? ???????? ??????? ?? ????????
  • ??????? ? ??????? ? ????? Monitor

100
Mutex
  • ????????? ?? WaitHandle
  • ???????? ?? ????????????? ?? OS
  • ??????????? Win32 synchronization handles
  • Mutex.WaitOne()
  • Mutex.ReleaseMutex()
  • ?????? ?? ?? ??????, ????? ???? ???? ????
    Mutex.WaitOne()
  • WaitHandle.WaitAll() ??????? ??? ??? ???????
    handle-a

101
Mutex ??????
class MutexDemo Mutex mMutex public
MutexDemo(Mutex aMutex) mMutex aMutex
public void PerformSomeTask()
m.WaitOne() Console.WriteLine("\nJob
started...") for( int i0 ilt10 i)
Thread.Sleep(100) Console.Write("")
Console.WriteLine("\nJob finished.")
m.ReleaseMutex()
102
???????????? 13
  • ????????????? ? Mutex

103
AutoResetEvent,ManualResetEvent
  • ?????????? ?? WaitHandle
  • ????????? ?? ?????????????
  • ???????????? Win32 synchronization handles
  • ????????????? ??? Set()
  • AutoResetEvent ??????????? ???? ??????
    ???????????(handle)
  • ?????? ??????????? ? nonsignaled state
  • ManualResetEvent() ??????????? ?????? ??????
    ????????????
  • ?????? ? signaled state, ?????? ????? ?? ??
    ???????

104
AutoResetEvent/ManualResetEvent
using System using System.Threading class
OneWhoWaits WaitHandle mWaitHandle int
mWaitTime public OneWhoWaits(WaitHandle
aWaitHandle, int waitTime )
mWaitHandle aWaitHandle mWaitTime
mWaitTime public void performSomeTask()
Thread.Sleep(mWaitTime)
Console.WriteLine("Thread 0 waiting",
Thread.CurrentThread.GetHashCode())
mWaitHandle.WaitOne() (???????? ??????????)
105
AutoResetEvent/ManualResetEvent
class MainClass static void Main()
ManualResetEvent evnt new
ManualResetEvent(false) for (int i0 ilt10
i ) OneWhoWaits oww new
OneWhoWaits(evnt, (i1)500) Thread thread
new Thread( new ThreadStart(oww.performS
omeTask)) thread.Start() for
(int i0 ilt10 i)
Console.ReadLine() evnt.Set()
106
???????????? 14
  • ????????????? ? AutoResetEvent ? ManualResetEvent

107
????????? ???????
  • System.Threading.Interlocked
  • ???????? ????????
  • System.Threading.ThreadPool
  • ???? ?????? ?? ?????
  • ???????????????? ?? ???????
  • ???????????? ?? ?? ????? ?? ?????? ?? ???????
    (????????? / ???????????)
  • System.Threading.ReaderWriterLock
  • ?????????? ???????????????? ????????
    Reader/Writer Problem
  • Synchronized Wrappers

108
System.Threading.Interlocked
  • ????????? ?????????? ?? ???????? ????????
    ?????????? ? 1, ????????? ? 1, ???????, ?????????
    ? ??.
  • ???? ????? ????????????? ?? ??????????? ?????
  • ? ??-???????? ?????? ??????????????? ???? ?? ??
    ??????? ? ???? ??????
  • ???????? ?? ??????? ??????????

109
System.Threading.Interlocked
  • Increment/Decrement
  • ???????? ???????? ?? ??????? ?? i/i--
  • Exchange
  • ??????? ?????????? ?? ??????? ????????? ? ??????,
    ????? ?????????
  • CompareExchange
  • ??? ??? ??????????
  • ????????? ???? ??????? ? ??????? ?? ?????, ???
    ??, ??????? ?????? ? ??????
  • ???????? ?? ??? ?????? ? ???????? ??????????

110
Interlocked ??????
class TestInterlockedIncrement static long
mUnsafeCounter 0 static long mSafeCounter
0 private static void DoTask() while
(true) mUnsafeCounter
Interlocked.Increment(ref mSafeCounter) if
(mSafeCounter 10000000 0)
Console.WriteLine("Safe0, Unsafe1",
mSafeCounter, mUnsafeCounter)
111
Interlocked ??????
static void Main(string args) for
(int i0 ilt5 i) Thread thread
new Thread( new ThreadStart(DoTask))
thread.Start() // ???????? //
Safe10000000, Unsafe5846325 // Safe20000000,
Unsafe15846326 // Safe30000000,
Unsafe25846326 // Safe40000000,
Unsafe35846325 // Safe50000000,
Unsafe41356463 // ...
112
Thread Pooling
  • ????? ????? ????????? ??-???????? ???? ?? ??????
    ?? ?????? (ThreadState.WaitSleepJoin) ??? ???????
    ??????? ???????
  • ????? ?? ???????? ???? ?? ????? ???????, ?? ??
    ???????? ??????????? ?? ??????? ??????? ??? ?? ??
    ??????? ???? ??????
  • ???????????? ?? ????? ????????? ????? ? ???????,
    ??????????? ? ????????? ???????

113
Thread Pooling
  • TP ? ?????? ?? ?????????? ?? ?????? ??? ?????????
    ? ??????????? ?? ?????
  • ??? TP ?? ???????? ????? ????? ? ???????? ??
    ???????????? ??????????
  • ??????? ?? ??????? ????? (worker threads)
  • ????? ????? ????? ? ?.???. Thread Pool
  • ??? ???? ??????, ?? ???????? worker thread, ????
    ???? ?? ????? ??????? ? ????
  • TP ?? ????? ?? ?????? ? ??????????????? ??
    ???????? ????? ???????
  • ???????????? ????? ?? ??????????? ?? ???? ?????

114
System.Threading.ThreadPool
  • .NET Framework ???????????? ????????? Thread
    Pooling ? ????? ThreadPool
  • ???????? ??, ?????? ?????? ?? ?? ??????? ????? ??
    ???? ?????? ??????, ????? ????? ?? ???????
    ?????????
  • ???????? ?? ???????? ?? ?????? ? ?? ?????????? ??
    ??????? ???????????? (?????? ???? worker threads)
  • ?? ???????????? ? Thread Pool-?? ??? ????? ?? 25
    ????? ?? ????????
  • ???? ?????? ???? ?? ??? ???? ???? Thread Pool
    ??? ? ??? ?? ?????? App Domains

115
System.Threading.ThreadPool
  • Thread Pool-?? ?? ????? ?????? ?? ??????? ?? ???
    ???????
  • ????????? ?? QueueUserWorkItem
  • ???????????? ?? ??????
  • ???????????? ?? ????????? ???????? ? callback
    ?????
  • .NET Framework ???????? Thread Pooling ??
  • ?????????? ??????????
  • ?????????? ????/?????
  • ?????? ? ???????
  • ?????? ??? ??????
  • ????????? ????????

116
System.Threading.ThreadPool
  • ??? ?????? ?????? ? ? Thread Pool, ?? ???? ?? ??
    ???????? ?? ????
  • Thread Pooling ????????? ?? OS ?? ??????????
    ???????????? ?? ?????, ??? ???? ????? ?? ?
    ?????????
  • ??????, ? ????? ?? ?? ?????????? ???????????? ??
    Thread Pool
  • ??? ? ????? ???????????? ?????
  • ??? ??????, ???????? ????? ????? ???? ?? ??
    ???????? ??????? ??????
  • ??? ??? ????? ?? ?????????????

117
ThreadPool.QueueUserWorkItem
class ThreadPoolDemo public static void
LongTask(object aParam)
Console.WriteLine("Started 0.", aParam)
Thread.Sleep(500) Console.WriteLine("Finished
0.", aParam) static void Main()
for (int i1 ilt100 i) string
taskName "Task" i ThreadPool.QueueUserW
orkItem(new WaitCallback(LongTask),
taskName) Console.ReadLine()
118
???????????? 15
  • ?????????? ?? ?????? ? Thread Pool

119
ThreadPool.RegisterWaitForSingleObject
  • ?????????? ???????, ????? ???? ?? ??????? (??
    ???? ????????????)
  • ???????? ?? ???
  • ?????????????
  • ??? ?????????? ?? ??????? timeout
  • ???????? ?? ????????? ? ????????? ?? ????????? ??
    ?? Thread Pool-?
  • ???? ?? ??????? ?? ?? ????????? ?????????
    ???????????

120
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
121
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
122
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
123
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
124
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
125
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
126
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
127
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
128
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
129
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
130
ThreadPool.RegisterWaitForSingleObject
using ... public class Example public static
void Main(string args) AutoResetEvent ev
new AutoResetEvent(false) object param
"some param" RegisteredWaitHandle r
ThreadPool.RegisterWaitForSingleObject(
ev, new WaitOrTimerCallback(WaitProc),
param, 1000, false ) Console.ReadLine()
Console.WriteLine("signaling.") ev.Set()
Console.ReadLine() Console.WriteLine("unregi
ster wait") r.Unregister(ev)
Console.ReadLine() public static void
WaitProc(object param, bool timedOut)
string cause "SIGNALED" if (timedOut)
cause "TIMED OUT" Console.WriteLine("WaitP
roc executescause 0", cause)
131
???????????? 16
  • RegisterWaitForSingleObject

132
?????????? ?????. ????????
  • The Producer-Consumer Problem
  • ???? ?????????? ? ???? ???????????? ???????? ???a
    ?????? (shared queue)
  • ??????????
  • ??? ???????? ? ??????, ???????????? ???????
    ?????? ?? ????? ???? ? ???
  • ??? ???????? ? ?????, ?????????????? ???????
    ?????? ?? ?? ??????? ?????
  • ?????????????? ? ???????????? ?? ????? ??
    ????????? ???????? ????????????
  • ?????? ???????? ?????
  • ?????? ?? ??? bounded buffer problem
  • ???? ?????????? ???? ? .NET

133
?????????? ?????. ????????
  • The Readers-Writers Problem
  • ???? ??? ?????? ?????? ? ???? ??? ?????? ??????
    ????????? ??? ??????
  • ?????? ?????? ?? ??? ???? ? OS
  • ??????? ?? ????????
  • ??????? ????? ????? ?? ????????? ????? ??????
  • ?????? ????? ???????? ???????, ???? ????? ????
    ???? ????? ???? ?? ?? ????????
  • ?????? ?? ???? ???? ?????/????? ?? ?? ????
    ????????? ????? ?? ?????????? ??????
  • ? .NET ReaderWriterLock

134
System.Threading.ReaderWriterLock
  • ???????????? ???-?????????? ????????????????
    ??????? Reader/Writer Problem
  • IsReaderLockHeld
  • IsWriterLockHeld
  • AcquireReaderLock
  • AcquireWriterLock
  • ReleaseReaderLock
  • ReleaseWriterLock

135
System.Threading.ReaderWriterLock
class Resource ReaderWriterLock rwl new
ReaderWriterLock() public void Read()
rwl.AcquireReaderLock(Timeout.Infinite) try
// Many can read, writers are blocked
finally rwl.ReleaseReaderLock()
public void Write()
rwl.AcquireWriterLock(Timeout.Infinite) try
// One can write, readers blocked
finally rwl.ReleaseWriterLock()

136
?????????? ?????. ????????
  • The Dining Philosophers Problem
  • ??????? ???????? ?????????? ?????? ???? ?
    ???????? ??? ??????
  • ?????? ?? ??????, ?? ???????? ?? ????? ?????? ??
    ????? ????????
  • ???????
  • ?? ?????? ????? ??????? ?? ???? ?? ????
  • ?? ?????? ?? ?? ????????? deadlock ?????? ?????
    ??????? ??? ?? ???? ?????? ? ???? ?? ???????

137
CustomReaderWriter
class CustomReaderWriter private int mReaders
0 private bool mIsWriting false public
void Read() lock( this )
while (mIsWriting) Monitor.Wait( this )
mReaders //...READING TAKES PLACE
HERE... lock( this )
mReaders-- if( mReaders 0 )
Monitor.Pulse(this) (????????
??????????)
138
CustomReaderWriter
class CustomReaderWriter private int mReaders
0 private bool mIsWriting false public
void Read() lock( this )
while (mIsWriting) Monitor.Wait( this )
mReaders //...READING TAKES PLACE
HERE... lock( this )
mReaders-- if( mReaders 0 )
Monitor.Pulse(this) (????????
??????????)
139
CustomReaderWriter
class CustomReaderWriter private int mReaders
0 private bool mIsWriting false public
void Read() lock( this )
while (mIsWriting) Monitor.Wait( this )
mReaders //...READING TAKES PLACE
HERE... lock( this )
mReaders-- if( mReaders 0 )
Monitor.Pulse(this) (????????
??????????)
140
CustomReaderWriter
class CustomReaderWriter private int mReaders
0 private bool mIsWriting false public
void Read() lock( this )
while (mIsWriting) Monitor.Wait( this )
mReaders //...READING TAKES PLACE
HERE... lock( this )
mReaders-- if( mReaders 0 )
Monitor.Pulse(this) (????????
??????????)
141
CustomReaderWriter
public void Write() lock( this )
while( mReaders ! 0 )
Monitor.Wait( this ) mIsWriting true
//...WRITING TAKES PLACE HERE...
lock( this ) mIsWriting false
Monitor.PulseAll( this )
142
CustomReaderWriter
public void Write() lock( this )
while( mReaders ! 0 )
Monitor.Wait( this ) mIsWriting true
//...WRITING TAKES PLACE HERE...
lock( this ) mIsWriting false
Monitor.PulseAll( this )
143
CustomReaderWriter
public void Write() lock( this )
while( mReaders ! 0 )
Write a Comment
User Comments (0)
About PowerShow.com