* Moves saga to Java 11 * Moves semaphore to Java 11 * Moves servant to Java 11 * Moves serverless to Java 11 * Moves service-layer to Java 11 * Moves service-locator to Java 11 * Moves sharding to Java 11 * Moves singleton to Java 11 * Moves spatial-partition to Java 11 * Moves specification to Java 11 * Moves state to Java 11 * Moves step-builder to Java 11 * Moves strategy to Java 11 * Moves subclass-sandbox to Java 11 * Fixes checkstyle issues
layout, title, folder, permalink, categories, tags
layout | title | folder | permalink | categories | tags | |
---|---|---|---|---|---|---|
pattern | Semaphore | semaphore | /patterns/semaphore/ | Concurrency |
|
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.
Class diagram
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
- [Semaphore(programming)] (http://en.wikipedia.org/wiki/Semaphore_(programming))
- [Semaphores] (http://tutorials.jenkov.com/java-concurrency/semaphores.html)