-
-
Notifications
You must be signed in to change notification settings - Fork 26.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added Join Pattern #3172
base: master
Are you sure you want to change the base?
Added Join Pattern #3172
Conversation
PR SummaryThis PR implements the Join design pattern, enabling synchronization of multiple threads. All Changes
autogenerated by presubmit.ai |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
✅ LGTM!
Review Summary
Commits Considered (7)
Files Processed (11)
- join/README.md (1 hunk)
- join/etc/JoinPatternFlowDiagram.png (0 hunks)
- join/etc/java-join-method.png (0 hunks)
- join/etc/join.urm.puml (1 hunk)
- join/pom.xml (1 hunk)
- join/src/main/java/com/iluwatar/join/DemoThread.java (1 hunk)
- join/src/main/java/com/iluwatar/join/DependentThread.java (1 hunk)
- join/src/main/java/com/iluwatar/join/JoinPattern.java (1 hunk)
- join/src/main/java/com/iluwatar/join/JoinPatternDemo.java (1 hunk)
- join/src/test/java/com/iluwatar/join/JoinPatternTest.java (1 hunk)
- pom.xml (1 hunk)
Actionable Comments (0)
Skipped Comments (0)
try { | ||
previous.join(); | ||
} catch (InterruptedException e) { | ||
e.printStackTrace(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Log to Slf4j log, not to console, e.g.
log.error("An error occurred: {}", e.getMessage(), e);
/** Here main thread will execute after completion of 4 demo threads | ||
* main thread will continue when CountDownLatch count becomes 0 | ||
* CountDownLatch will start with count 4 and 4 demo threads will decrease it by 1 | ||
* everytime when they will finish . | ||
*/ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Explain the pattern briefly. After that explain how the code example implements it. Add comments to the code where necessary. Remember, this is material for studying design patterns.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
✅ LGTM!
Review Summary
Commits Considered (3)
- c2dfb65: Merge branch 'f2' of https://github.com/keshavMM004/java-design-patterns into f2
- 3b4bc80: updated README.MD
- 2ca371c: Merge branch 'master' of https://github.com/keshavMM004/java-design-patterns into f2
Files Processed (7)
- join/README.md (1 hunk)
- join/etc/join.urm.puml (1 hunk)
- join/src/main/java/com/iluwatar/join/DemoThread.java (1 hunk)
- join/src/main/java/com/iluwatar/join/DependentThread.java (1 hunk)
- join/src/main/java/com/iluwatar/join/JoinPattern.java (1 hunk)
- join/src/main/java/com/iluwatar/join/JoinPatternDemo.java (1 hunk)
- pom.xml (1 hunk)
Actionable Comments (0)
Skipped Comments (0)
Quality Gate failedFailed conditions |
package com.iluwatar.join; | ||
|
||
import lombok.extern.slf4j.Slf4j; | ||
|
||
/** Here main thread will execute after completion of 4 demo threads | ||
* main thread will continue when CountDownLatch count becomes 0 | ||
* CountDownLatch will start with count 4 and 4 demo threads will decrease it by 1 | ||
* everytime when they will finish . | ||
* DemoThreads are implemented in join pattern such that every newly created thread | ||
* waits for the completion of previous thread by previous.join() . Hence maintaining | ||
* execution order of demo threads . | ||
* JoinPattern object ensures that dependent threads execute only after completion of | ||
* demo threads by pattern.await() . This method keep the main thread in waiting state | ||
* until countdown latch becomes 0 . CountdownLatch will become 0 as all demo threads | ||
* will be completed as each of them have decreased it by 1 and its initial count was set to noOfDemoThreads. | ||
* Hence this pattern ensures dependent threads will start only after completion of demo threads . | ||
*/ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Keep the code example minimal. Leave out headers and imports and such. It doesn't have to compile, but the reader has to understand.
@Test | ||
public void test() throws InterruptedException { | ||
|
||
int noOfDemoThreads = 4; | ||
int[] executionOrder = {1, 4, 3, 2}; | ||
JoinPattern pattern = new JoinPattern(noOfDemoThreads, executionOrder); | ||
|
||
Thread previous = null; | ||
|
||
for (int i = 0; i < noOfDemoThreads; i++) { | ||
previous = new Thread(new DemoThread(executionOrder[i], previous)); | ||
previous.start(); | ||
|
||
} | ||
pattern.await(); | ||
|
||
int[] actualExecutionOrder = DemoThread.getActualExecutionOrder(); | ||
|
||
assertArrayEquals(executionOrder, actualExecutionOrder, "Demo threads did not execute in given order "); | ||
|
||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We need more test coverage. Use Sonar analysis to identify untested code.
int[] executionOrder = {4, 2, 1, 3}; | ||
int noOfDemoThreads = 4; | ||
int noOfDependentThreads = 2; | ||
JoinPattern pattern = new JoinPattern(noOfDemoThreads, executionOrder); | ||
Thread previous = null; | ||
|
||
for (int i = 0; i < noOfDemoThreads; i++) { | ||
previous = new Thread(new DemoThread(executionOrder[i], previous)); | ||
previous.start(); | ||
} | ||
pattern.await(); | ||
|
||
//Dependent threads after execution of DemoThreads | ||
for (int i = 0; i < noOfDependentThreads; i++) { | ||
new Thread(new DependentThread(i + 1)).start(); | ||
} | ||
LOGGER.info("end of program "); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add clear comments explaining what is happening in each step
Implemented the join design pattern that allows multiple threads to be synchronized such that all DemoThreads must complete before any DependentThreads can proceed .
Close #70