Java Multithreading

Unveiling the mysteries of multithreading in Java. The ultimate Java multithreading course
  • Lectures 16
  • Video 3 Hours
  • Skill level all level
  • Languages English
  • Includes Lifetime access
    30 day money back guarantee!
    Available on iOS and Android
    Certificate of Completion

How taking a course works

Discover

Find online courses made by experts from around the world.

Learn

Take your courses with you and learn anywhere, anytime.

Master

Learn and practice real-world skills and achieve your goals.

Course Description

Discover how to write effective multi-threaded code in Java; learn why problems can occur with Java multithreading and how to fix those problems.

What are the requirements?

  • Some knowledge of Java

What am I going to get from this course?

  • Over 16 lectures and 3 hours of content!
  • Understand Java multi-threading
  • Be able to write effective muli-threaded code

What is the target audience?

  • Java developers
  • Java beginners who don't mind a steep learning curve

What you get with this course?

Not for you? No problem.
30 day money back guarantee

Forever yours.
Lifetime access

Learn on the go.
Desktop, iOS and Android

Get rewarded.
Certificate of completion

Curriculum

Section 1: My First Section
09:58

In this tutorial we'll look at the two main ways to start a thread in Java. If you want to start lots of threads all at once you'll want to use thread pools, which we'll look at in a future tutorial; the methods in this tutorial are most suitable for starting one or a small number of threads. In case you're going for a job interview or taking an exam, this is a classic interview/exam question!

09:49

This video looks at basic thread communication in Java using boolean flags with the volatile keyword. I also take a look at why volatile isn't good enough for most situations.

13:15

The basics of using the synchronized keyword in Java to stop threads messing up each other's work. What's an intrinsic lock, and why do we need it? 

18:15

How to speed up your multithreaded code by locking only those sections of code that you need to, rather than using synchronized methods and locking your whole object. Don't forget to maximize to fullscreen so you can see the code. You can also find the code on caveofprogramming.com.

09:11

How to use thread pools to manage lots of threads to complete lots of similar tasks. Source code available on caveofprogramming.com

08:06

How to use the fantastic CountDownLatch class in Java to simplify your multithreaded code.


</p>
11:10

A tutorial on how to implement the producer-consumer pattern in Java using the ArrayBlockingQueue Java class. Producer-Consumer is the situation where one or more threads are producing data items and adding them to a shared data store of some kind while one or more other threads process those items, removing them from the data store.

10:21

A tutorial on wait and notify; low-level thread synchronization methods in Java that allow you to avoid having vile process-consuming polling loops in your code. Code on caveofprogramming.com. Wait and notify allow you to have sleeping threads that are woken up by other threads. "Why, exactly what I've been looking for!" I hear you say. Yes, even people who don't program in Java can enjoy using these fantastic methods. OK, maybe that's going a bit far.


10:10

A tutorial on how to implement the producer-consumer pattern in Java using the "low level" keywords wait, notify and synchronize. (See tutorial 7 for the high level version). Code on www.caveofprogramming.com

11:30

How to use the ReentrantLock class in Java as an alternative to synchronized code blocks. ReentrantLocks let you do all the stuff that you can do with synchronized, wait and notify, plus some more stuff besides that may come in handy from time to time.

14:39

The causes of deadlock and two things you can do about it. This video also covers how to write a method that can safely acquire any number of locks in any order without causing deadlock, using the tryLock() method of ReentrantLock.

10:55
How to use Semaphores in multi-threaded Java code. Semaphores allow you to control how many threads can access a resource simultaneously; you can also use them as locks if the mood takes you, with the advantage that you can release (unlock) them from threads other than where you locked them.
Callable and Future
11:32
08:40
Finally it's time to figure out what those pesky InterruptedExceptions are for.
20:11
Multithreading in Swing (GUI) programs presents a few unique difficulties, since you can't (or at least you're not supposed to) update the GUI from another thread. The SwingWorker class can help you out a lot.
Section 2: Looking for Source Code?
Source code ....
Text

Instructor Biography

John Purcell , Software Development Trainer

After working as a software developer and contractor for over 14 years for a whole bunch of companies including CSC, Proquest, SPSS and AT&T in the UK and Netherlands, I decided to work full-time as a private software trainer. I now live in the beautiful city of Budapest, Hungary, from where I run the website Cave of Programming.

Join the biggest student community

7,000,000

Hours of video content

26,000,000

Course Enrollments

7,100,000

Students

Reviews

Average Rating
4.7
Details
  1. 5 Stars
    330
  2. 4 Stars
    82
  3. 3 Stars
    16
  4. 2 Stars
    2
  5. 1 Stars
    2
    • A S M Atiqur Rahim Khan

    Good course

    Course is good for beginners like me. However it lacks practical application examples of multi-threading.

    • Prasad Choudhary

    Awesome..

    simple and straight forward, very clear and precise , thanks for making such a great contain

    • Marvin Williams

    Informative

    This course was very informative about java multithreading

    • Rahul Bhatt

    Good refresher for Java multithreading

    Plain, simple explanations of multithreading constructs in Java.

    • Rajesh Twanabasu

    Java Multithreading Tutorial

    Nice tuts.

Show more reviews
Ready to start learning?
Enroll for free now