Thread 常用API(详细解析)

简介: 学习 Thread 的常用API,包括 start、run、join、sleep、interrupt、yield、currentThread 方法的概念、使用方法以及代码实例

start()

启动线程,运行 run 方法中的代码
注意

  • start 方法只是让 线程进入了 就绪,而不是马上运行,需要等待CPU的时间片
  • 一个线程只能调用一次 start,否则会出现 IllegalThreadStateException

代码实例

        Thread t1=new Thread(() -> {
   
            System.out.println("线程1 运行");
        });
        Thread t2=new Thread(() -> {
   
            System.out.println("线程2 运行");
        });

        t1.start();
        t2.start();

上面代码的的运行结果可能是

线程2 运行
线程1 运行

虽然 线程1 比 线程2 更早进入就绪态,但是 线程2 比 线程1 更早获取到CPU时间片,因此更早执行

run()

在该方法中定义线程要完成的任务

以下是Runnable接口的源码

@FunctionalInterface
public interface Runnable {
   
    public abstract void run();
}

可以看到加了 @FunctionalInterface ,是函数式接口,并且只有一个run方法

我们看Thread源码,发现Thread的run方法就是来源于 Runnable 接口

public class Thread implements Runnable

我们可以直接重写 Thread 中的run方法,比如

        Thread t3 = new Thread(){
   
            @Override
            public void run() {
   
                System.out.println("线程3 运行");
            }
        };
        t3.start();

也可以继承 Thread 类后再重写

public class MyThread extends Thread {
   
    @Override
    public void run() {
   
        System.out.println("MyThread...run...");
    }    
    public static void main(String[] args) {
   
        // 创建MyThread对象
        MyThread t1 = new MyThread() ;
        MyThread t2 = new MyThread() ; 
    }

}

观察Thread源码,发现存在Runnable属性

    /* What will be run. */
    private Runnable target;

因此,也可以在构造 Thread 对象时传递 Runnable 参数,则线程启动后会调用 Runnable 中的 run 方法

代码实例

        Thread t1=new Thread(() -> {
   
            System.out.println("线程1 运行");
        });
        Thread t2=new Thread(() -> {
   
            System.out.println("线程2 运行");
        });

        t1.start();
        t2.start();

在上面的代码中,调用的 Thread 构造方法,如下

    public Thread(Runnable target) {
   
        init(null, target, "Thread-" + nextThreadNum(), 0);
    }

我们使用Lambda表达式实现了Runnable接口的run方法

可以用一句话概括,如果 Thead 类上的Runnable属性不为null,则执行该Runnable属性的run方法,否则执行Thread自己的run方法

join() 和 join(long n)

join() -- 等待线程运行结束
join(long n) -- 等待线程运行结束,最多等待 n 毫秒

        Thread t3 = new Thread(){
   
            @Override
            public void run() {
   
                try {
   
                    Thread.sleep(10000);
                } catch (InterruptedException e) {
   
                    e.printStackTrace();
                }
            }
        };
        t3.start();

        t3.join();

        System.out.println("main 继续执行");

执行上面的代码会发现,无论如何都会等待至少10秒才会输出 "main 继续执行"

sleep(long n)

sleep是Thread的静态方法

作用是:让当前执行的线程休眠n毫秒,休眠时让出 cpu 的时间片给其它线程

上面的代码实例就已经使用到 sleep 方法

哪个线程调用了 Thread.sleep(10000) ,哪个线程睡眠

比如在上面的代码实例中,线程3 会睡眠 10 秒,而 主线程 并不会睡眠

另外

  • 睡眠结束后的线程未必会立刻得到执行
  • 其它线程可以使用 interrupt 方法打断正在睡眠的线程,这时 sleep 方法会抛出 InterruptedException
  • 建议用 TimeUnit 的 sleep 代替 Thread 的 sleep来获得更好的可读性 (TimeUnit 的 sleep方法与 Thread的sleep方法相同)

interrupt()

interrupt 打断线程

无论线程处在阻塞(sleep、wait、join)还是运行状态,都可以被打断

如果被打断线程正在 sleep、wait、join 会导致被打断的线程抛出 InterruptedException,并清除 打断标记 ;如果打断的正在运行的线程,则会设置 打断标记 ;

interrupt 是非静态方法,需要打断哪个线程,就调用那个线程的 interrupt方法

代码实例

    private static void test1() throws InterruptedException {
   
        Thread t1 = new Thread(()->{
   
            try {
   
                Thread.sleep(1000);
            } catch (InterruptedException e) {
   
                e.printStackTrace();
            }
        }, "t1");
        t1.start();
        Thread.sleep(500);
        t1.interrupt();
    }

yield()

sleep 能使线程让出 CPU时间片

而 yield方法 同样 能使线程让出CPU时间片

但是 调用 yield 方法时,线程不一定会马上让出CPU,这取决于操作系统的任务调度器

而且 sleep 方法是让线程从 Running 进入 Timed Waiting 状态(阻塞),yield是让当前线程从 Running 进入 Runnable 就绪状态

yield方法也是个静态方法

currentThread()

public static native Thread currentThread();

可以看到currentThread也是个静态方法,并且返回值是Thread

用法 -- 在哪个线程中调用 Thread.currentThread ,就会返回当前线程的 Thread 对象,有点类似 this 关键字

目录
相关文章
|
10天前
|
安全 NoSQL API
拼多多:通过微信支付API实现社交裂变付款的技术解析
基于微信JSAPI构建社交裂变支付系统,用户发起拼单后生成预订单与分享链接,好友代付后通过回调更新订单并触发奖励。集成微信支付、异步处理、签名验签与Redis关系绑定,提升支付成功率与裂变系数,实现高效安全的闭环支付。
136 0
|
10天前
|
存储 算法 API
唯品会智能分仓API技术解析:基于收货地址自动匹配最近仓库
唯品会智能分仓API通过地理编码与Haversine距离算法,自动将订单匹配至最近仓库,提升配送效率、降低成本。本文详解其技术原理、实现步骤与应用优势,助力开发者构建高效物流系统。(239字)
56 0
|
13天前
|
人工智能 供应链 API
淘宝API商品详情接口全解析:从基础数据到深度挖掘
淘宝API商品详情接口不仅提供基础数据,更通过深度挖掘实现从数据到洞察的跨越。开发者需结合业务场景选择合适分析方法,利用AI标签、区块链溯源等新技术,最终实现数据驱动的电商业务创新。
|
17天前
|
JSON 缓存 自然语言处理
多语言实时数据微店商品详情API:技术实现与JSON数据解析指南
通过以上技术实现与解析指南,开发者可高效构建支持多语言的实时商品详情系统,满足全球化电商场景需求。
|
18天前
|
JSON 自然语言处理 API
多语言实时数据淘宝商品评论API:技术实现与JSON数据解析指南
淘宝商品评论多语言实时采集需结合官方API与后处理技术实现。建议优先通过地域站点适配获取本地化评论,辅以机器翻译完成多语言转换。在合规前提下,企业可构建多语言评论数据库,支撑全球化市场分析与产品优化。
存储 人工智能 安全
154 4
|
24天前
|
数据采集 算法 API
2025 电商 API 接口全解析:从接入到实战的通用指南
本文系统解析了电商 API 的核心价值、分类及 2025 年最新趋势,涵盖商品、订单、支付、用户四大模块。内容包括 API 接入的通用前置准备、核心场景实战案例及避坑策略,强调合规性、实时性与智能化应用。适用于企业及开发者高效对接主流电商平台。
|
24天前
|
JSON 供应链 监控
1688商品详情API技术深度解析:从接口架构到数据融合实战
1688商品详情API(item_get接口)可通过商品ID获取标题、价格、库存、SKU等核心数据,适用于价格监控、供应链管理等场景。支持JSON格式返回,需企业认证。Python示例展示如何调用接口获取商品信息。
|
25天前
|
监控 算法 API
1688商品列表API数据解析
1688商品列表API支持通过关键词、价格、类目筛选商品,适用于电商分析与竞品监控,提供分钟级更新与高并发能力。支持批量获取商品信息、分页查询,附Python调用示例及完整错误处理逻辑。
|
26天前
|
算法 API 数据安全/隐私保护
深度解析京东图片搜索API:从图像识别到商品匹配的算法实践
京东图片搜索API基于图像识别技术,支持通过上传图片或图片URL搜索相似商品,提供智能匹配、结果筛选、分页查询等功能。适用于比价、竞品分析、推荐系统等场景。支持Python等开发语言,提供详细请求示例与文档。

热门文章

最新文章

推荐镜像

更多
  • DNS