Skip to content

Latest commit

 

History

History
33 lines (26 loc) · 875 Bytes

README.md

File metadata and controls

33 lines (26 loc) · 875 Bytes
layout title folder permalink categories tags
pattern
Semaphore
semaphore
/patterns/semaphore/
Concurrency
Java
Difficulty-Intermediate

Also known as

Counting Semaphore

Intent

Create a lock which mediates access to a pool of resources. Only a limited number of threads, specified at the creation of the semaphore, can access the resources at any given time. A semaphore which only allows one concurrent access to a resource is called a binary semaphore.

alt text

Applicability

Use a Semaphore when

  • you have a pool of resources to allocate to different threads
  • concurrent access to a resource could lead to a race condition

Credits