Java Concurrency & Multithreading: beginner to intermediate
Learn Java multi-threading and resolve data and race conditions with volatile, atomics, and synchronized
4.82 (14 reviews)

103
students
4 hours
content
May 2023
last update
$49.99
regular price
What you will learn
A high-level overview of process management by the operating system
A high-level overview of thread management by the operating system
The fundamental difference between a process and a thread
How to define a thread using the Thread subclassing approach
How to define a thread by implementing the Runnable interface
The different states of a thread and its lifecycle
How to start threads using the start() method and the ExecutorService
The strategy for reusing threads employed by the ExecutorService
How to define a thread by implementing the Callable interface
How to use the Future interface in blocking and non-blocking ways
The usage of daemon threads
The functionality of the Thread's .join() and .interrupt() methods
The concept of data race and its details
How to use the 'volatile' keyword to avoid data race
The concept of mutex / intrinsic lock / monitor
The concept of race condition, its details and difference from the data race
How to use the 'synchronized' keyword to implement mutex/monitor acquire in Java
The concept of the compare-and-swap CPU instruction
A high-level overview of the Java atomics package and its relation to compare-and-swap
How to use the AtomicInteger class to avoid arithmetic operation race condition
The usage of the ThreadLocal class in Java
How to take thread dumps of the JVM process
How to use the .parallelStream() method in the Java Streaming API
Related Topics
5218938
udemy ID
3/18/2023
course created date
7/26/2024
course indexed date
Bot
course submited by