JAVA拾遗 - 线程的三种简单实现

本文介绍了Java中实现线程的三种方法:继承Thread类并覆盖run()方法;实现Runnable接口并实现run()方法;实现Callable接口并实现call()方法。通过示例代码详细解释了每种方法的特点及应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程是程序中的执行线程。java虚拟机允许应用程序并发地运行多个执行线程。每个线程都有一个优先级,高优先级线程的执行优先于低优先级的线程。当某个线程中运行的代码创建一个新Thread对象时,该新线程的初始化优先级被设定为创建线程的优先级,并且当且仅当创建线程是守护线程时,新线程才是守护程序。当java虚拟机启动时,通常都会有一个单独非守护线程(通常用来调用“main()”函数)。JAVA虚拟机会继续执行线程,直到下列情况出现:
1. 调用了Runtime 类的exit方法,并且安全管理器允许退出操作的发生
2. 非守护线程的所有线程都已经停止运行,无论是通过对run方法的调用中返回,还是抛出一个传播到run方法之外的异常 

线程的三种简单实现

1.使用extends Thread覆盖run()方法:

package Thread;

public class threadTest_1 extends Thread {
    public void run()
    {
        super.run();
        try{
            Thread.sleep(1000);
        }
        catch(InterruptedException e)
        {
            e.printStackTrace();
        }
        System.out.println("这是线程A");
    }
    public static void main(String args[])
    {
        threadTest_1 a = new threadTest_1();
        a.start();
        System.out.println("这是主线程");
    }
}

输出为:

这是主线程
这是线程A

2.实现Runnable接口,实现run()方法。

package Thread;

public class threadTest_2 implements Runnable{
    public void run()
    {
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        System.out.println("这是进程B");
    }
    public static void main(String args[])
    {
        threadTest_2 b = new threadTest_2();
        new Thread(b).start();
        System.out.println("这是主线程:");
    }

}

输出为:

这是主线程:
这是进程B

3.第三种实现方式是implements Callable,实现call()方法可以得到线程的执行结果

package Thread;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

public class threadTest_3 implements Callable<String>{
    public String call()
    {
        try {
            Thread.sleep(500L);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        System.out.println("这是线程 C");
        return "thread C";
    }
    public static void main(String args[])
    {
        threadTest_3 c = new threadTest_3();
        FutureTask<String> faeature =  new FutureTask<String>(c);
        new Thread(faeature).start();
        System.out.println("这是主线程:begin!");
        try {
            System.out.println("得到的返回结果是:" + faeature.get());
        } catch (InterruptedException | ExecutionException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        System.out.println("这是主线程:end!");
    }

}

输出为:

这是主线程:begin!
这是线程 C
得到的返回结果是:thread C
这是主线程:end

结语:仔细研读代码和体会上面三种实现方法的优缺点和不同之处,比较其运行结果,并且也要注意到运行和执行开启线程的方法也不相同。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值