java并发编程中的runnable和callable接口详解
Java利用线程实现并发,而Runnable和Callable是定义线程执行任务的两个核心接口。
1. Runnable接口

Runnable接口代表一个可由线程并发执行的任务。它包含一个run()方法,其中编写需要执行的代码。Runnable接口不返回结果,也不抛出检查型异常(checked exceptions)。
示例代码:
小型企业入门套件(The Small Business Starter Kit)提供了一个商业宣传网站的完整演示,他适合中小型企业。使用他创建的网站支持自定义模板,具有先进的功能,包括:内容和数据管理的SQL和XML数据源整合。该源码包含C#和VB两个版本,只有前台部分源码,微软官方截止到51aspx发布源码时还没有提供后台代码。小型企业网站入门套件的关键页面包括:产品分类显示新闻发布显示商户认证
立即学习“Java免费学习笔记(深入)”;
public class RunnableExample implements Runnable {
@Override
public void run() {
System.out.println("Runnable is running!");
}
public static void main(String[] args) {
RunnableExample example = new RunnableExample();
Thread thread = new Thread(example);
thread.start();
}
}
说明:
-
RunnableExample实现Runnable接口。 -
run()方法打印信息到控制台。 -
main方法创建一个RunnableExample实例,并用它创建一个Thread,然后启动线程,在新的线程中执行run()方法。
2. Callable接口

Callable接口与Runnable类似,但也有区别。它代表一个返回结果并可以抛出检查型异常的任务。必须实现的call()方法返回结果,并能处理异常。
示例代码:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class CallableExample implements Callable{ @Override public String call() throws Exception { return "Callable has returned a result!"; } public static void main(String[] args) { CallableExample example = new CallableExample(); FutureTask futureTask = new FutureTask<>(example); Thread thread = new Thread(futureTask); thread.start(); try { System.out.println(futureTask.get()); } catch (InterruptedException | ExecutionException e) { e.printStackTrace(); } } }
说明:
-
CallableExample使用泛型String,实现Callable接口。 -
call()方法返回一个结果字符串。 -
FutureTask包装Callable任务,允许在任务完成后获取结果。
3. Runnable和Callable的主要区别

选择Runnable还是Callable取决于具体场景:
| 特性 | Runnable | Callable |
|---|---|---|
| 返回值 | 无 | 有 |
| 异常处理 | 只能抛出运行时异常 (RuntimeException) | 可以抛出检查型异常 (Checked Exception) |
4. 实际应用示例
4.1 使用Runnable执行后台任务
Runnable常用于不需要返回结果的后台任务,例如定期更新或处理用户交互。
4.2 使用Callable处理需要结果的任务
Callable适合需要结果或需要处理异常的任务,例如执行计算或从数据源获取数据。 以下是一个使用ExecutorService更优雅地处理Callable的例子:
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; public class ComputationTask implements Callable{ @Override public Integer call() throws Exception { int sum = 0; for (int i = 0; i < 1000; i++) { sum += i; } return sum; } public static void main(String[] args) throws ExecutionException, InterruptedException { ExecutorService executor = Executors.newSingleThreadExecutor(); Future future = executor.submit(new ComputationTask()); try { System.out.println("Result of computation: " + future.get()); } finally { executor.shutdown(); } } }
5. 结论
Runnable和Callable是Java并发编程中处理任务的关键接口,各有用途。Runnable适用于不需要返回结果的任务,而Callable适用于需要返回结果并处理异常的任务。 理解它们的区别和应用场景能显著提高并发编程能力。









