前言,三种使用线程的方法:实现Runnable接口、实现Callable接口、继承Thread类。实现接口会更好,因为继承了Thread类就无法继承其他类,但可以实现多个接口
/**
* 线程状态:new、runnable、blocked、time waiting、waiting、terminated
* 类可能只要求可执行就行,继承整个Thread类开销过大
*/
一、实现Runnable接口
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | // 线程使用方式:实现Runnable接口,需要实现run()方法,通过Thread调用start()来启动线程 class MyRunnable implements Runnable { @Override public void run() { m1(); } public void m1(){ System.out.println( "do something" ); } public static void main(String[] args) { MyRunnable instance = new MyRunnable(); Thread thread = new Thread(instance); thread.start(); } } |
二、实现Callable接口
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | // 线程使用方式:实现Callable接口,与Runnable相比,Callable可以有返回值,返回值通过FutureTask封装 class MyCallable implements Callable<Integer> { @Override public Integer call() throws Exception { return m1(); } public Integer m1(){ return 123 ; } public static void main(String[] args) throws ExecutionException, InterruptedException { MyCallable myCallable = new MyCallable(); FutureTask<Integer> futureTask = new FutureTask<>(myCallable); Thread thread = new Thread(futureTask); thread.start(); System.out.println(futureTask.get()); } } |
三、继承Thread类:
继承Thread类,同样也是需要实现run方法,因为Thread类也实现了Runnable接口;
当调用start()方法启动一个线程时,虚拟机会将该线程放入就绪队列等待调度,当一个线程被调度时就会执行该线程的start()方法
1 2 3 4 5 6 7 8 9 10 11 12 | class MyThread extends Thread{ public void run(){ System.out.println( "do something" ); } public static void main(String[] args) { Thread thread = new MyThread(); thread.start(); } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理