layout, title, folder, permalink, pumlid, categories, tags
layout | title | folder | permalink | pumlid | categories | tags | ||
---|---|---|---|---|---|---|---|---|
pattern | Half-Sync/Half-Async | half-sync-half-async | /patterns/half-sync-half-async/ | RScv3SCm3030LU819FRPXg5fIm552tnYPFiyjRi3RkbAaYkdoQr5JBy369vrxz7oaSv6XmPhL3e6TCaJ0msU-CAoilTToyG8DdKOw5z0GzcAlvNAN_WZSD1brBHHPmxv0000 | Concurrency |
|
Intent
The Half-Sync/Half-Async pattern decouples synchronous I/O from asynchronous I/O in a system to simplify concurrent programming effort without degrading execution efficiency.
Applicability
Use Half-Sync/Half-Async pattern when
- a system possesses following characteristics:
- the system must perform tasks in response to external events that occur asynchronously, like hardware interrupts in OS
- it is inefficient to dedicate separate thread of control to perform synchronous I/O for each external source of event
- the higher level tasks in the system can be simplified significantly if I/O is performed synchronously.
- one or more tasks in a system must run in a single thread of control, while other tasks may benefit from multi-threading.