Save up to 80 % on our C# e-learning courses. Only this week!
Get up to 80 % extra points for free! More info

Lesson 9 - Java Multithreading - Runnable, Callable, Future, Executor

In the previous lesson, Multithreading in Java - Barrier, CountDownLatch, we got familiar with the barrier. In today's tutorial, we're going to take a closer look at Runnable, Callable, and Future interfaces. We'll introduce their methods and differences. In the second part of the article we'll focus on the Executor interface. There will be no implementations in this lesson.

Runnable, Callable, and Future

These three interfaces are the basis of multithreading in Java.


We've already encountered the Runnable interface at the beginning when we were learning to create threads. One way to create a thread was through its constructor with a Runnable parameter. This interface contains only one method:

public interface Runnable {
  public void run();

The body of the run() method is executed on the thread and the thread terminates when it's done. This interface is perfect for some simple tasks, but it has one important drawback: if the thread was calculating something, there's no easy way to tell the "parent" that the calculation has finished (or failed). We'd have to use, for example, a semaphore or a barrier. The next interface tries to fix this problem.


This interface is generic, which means that we have to specify the data type in angle brackets when implementing it. This data type represents the result that the method will return once the "calculation" is completed:


...End of the preview...

Premium article

Premium article is a large database made up of manuals and tutorials, whose main goal is to provide high-quality IT education to everyone. We started out in the Czech republic, where we display roughly a million articles per month and receive plenty of gratitude from our users. Thanks to our successful establishment, we are now bringing these articles to the rest of the world.

Although we are trying to keep our content free of charge, maintaining the site is a huge effort for everyone involved. Therefore, some content (exercises and more advanced material) costs network points. Don't worry, they're really cheap :)

Article description

Requested article covers this content:

In this Java article we'll introduce advanced techniques for parallel programming. We'll describe the Runnable, Callable, Future and Executor interfaces.

Limited offer: Learn all knowledge and save money

Buy articles and tests separately one by one 102 points
Buy all currently available articles in the section including all features for an exclusive price 87 points
Currently, you have 0 points
By buying this exclusive package, you'll have access to all 13 articles in this course including exercise submitting while saving $1.38. This offer is limited for the first articles only with an additional exclusive 15% discount.
You gain 87 points for adding an article to the site, or for $9.18 $7.80

Warning, by buying just this article you'll lose the limited 15% discount for the package of all the articles.

To access the article, you need 10 points
Currently, you have 0 points
You gain 10 points for adding an article to the site, or for $0.90

Buying this article gives you unlimited access to it forever. You will learn some more and help us keep giving our site maintenance which helps you and others get better futures. It's a win-win.

This article is licensed: Premium, by buying this article, you agree with the terms of use.

You gain points by supporting our network. This is done by sending a helpful amount of money to support the site, or by creating content for the network.

You can get points immediately using:

Credit card SMS Wire transfer
Credit card SMS Wire transfer
Article has been written for you by Petr Štechmüller
Activities (3)