如何用Java创建和使用线程类 Java线程创建方式与示例

java中创建线程的核心方式有两种:实现runnable接口和继承thread类。1. 实现runnable接口更灵活,适合类已继承其他类或需任务与线程解耦的场景,通过将任务逻辑与线程分离,实现更好的复用性和设计灵活性。2. 继承thread类较直观,但受限于java单继承机制,线程类无法再继承其他类,任务逻辑与线程本身紧密耦合,复用性较差。两种方式均可创建线程并执行任务,但runnable方式更推荐使用,尤其结合线程池可提升并发管理效率。

如何用Java创建和使用线程类 Java线程创建方式与示例

在Java中创建和使用线程,核心思路其实就两种:要么实现Runnable接口,要么继承Thread类。这两种方式各有千秋,但最终目的都是让你的程序能够并行处理任务,提升效率,或者处理一些需要后台运行的逻辑。选择哪种,很多时候取决于你的具体场景和个人偏好,但通常来说,实现Runnable接口会是更推荐的做法。

如何用Java创建和使用线程类 Java线程创建方式与示例

解决方案

要创建和使用Java线程,我们主要围绕Runnable接口和Thread类展开。

1. 实现Runnable接口

立即学习“Java免费学习笔记(深入)”;

如何用Java创建和使用线程类 Java线程创建方式与示例

这是我个人觉得更灵活、也更符合Java设计哲学的方式。当你的类已经继承了其他类,或者你希望将任务逻辑与线程本身解耦时,Runnable就是你的不二之选。

// 定义一个实现Runnable接口的任务class MyRunnableTask implements Runnable {    private String taskName;    public MyRunnableTask(String name) {        this.taskName = name;    }    @Override    public void run() {        // 线程执行的逻辑写在这里        System.out.println(Thread.currentThread().getName() + " 正在执行任务: " + taskName);        try {            Thread.sleep(1000); // 模拟耗时操作        } catch (InterruptedException e) {            System.out.println(Thread.currentThread().getName() + " 的任务被中断了!");            Thread.currentThread().interrupt(); // 重新设置中断标志        }        System.out.println(Thread.currentThread().getName() + " 完成任务: " + taskName);    }}public class ThreadWithRunnableDemo {    public static void main(String[] args) {        // 创建Runnable任务实例        MyRunnableTask task1 = new MyRunnableTask("下载文件");        MyRunnableTask task2 = new MyRunnableTask("处理数据");        // 将Runnable任务包装到Thread对象中        Thread thread1 = new Thread(task1, "下载线程");        Thread thread2 = new Thread(task2, "处理线程");        // 启动线程,执行run方法中的逻辑        thread1.start();        thread2.start();        System.out.println("主线程继续执行...");    }}

你看,这里MyRunnableTask只关注它要“做什么”,而Thread对象则负责“如何运行”这个任务。这种分离,让代码结构清晰,也更容易复用。

如何用Java创建和使用线程类 Java线程创建方式与示例

2. 继承Thread

这种方式直观,但有其局限性。如果你希望你的线程类除了线程功能外,不再需要继承其他任何类,那么这种方式也挺方便。

// 定义一个继承Thread类的线程class MyThread extends Thread {    private String threadName;    public MyThread(String name) {        super(name); // 调用父类构造器设置线程名        this.threadName = name;    }    @Override    public void run() {        // 线程执行的逻辑        System.out.println(threadName + " 启动了!");        for (int i = 0; i < 3; i++) {            System.out.println(threadName + " 正在执行计数: " + i);            try {                Thread.sleep(500);            } catch (InterruptedException e) {                System.out.println(threadName + " 被中断了!");                Thread.currentThread().interrupt();            }        }        System.out.println(threadName + " 运行结束。");    }}public class ThreadExtendsThreadDemo {    public static void main(String[] args) {        // 创建并启动线程实例        MyThread threadA = new MyThread("线程A");        MyThread threadB = new MyThread("线程B");        threadA.start();        threadB.start();        System.out.println("主线程也在忙活...");    }}

这里,MyThread本身就是一个线程。你直接创建它的实例,然后调用start()就行了。

Java线程的两种核心创建方式有何区别

这两种方式,虽然都能达到创建线程的目的,但它们在设计理念和实际使用中有着明显的区别,理解这些区别对于写出健壮的并发程序至关重要。

首先,最直接的区别在于Java的单继承限制。Java类只能继承一个父类。如果你选择继承Thread类来创建线程,那么你的线程类就不能再继承其他任何类了。这在很多时候是个大问题,比如你的业务逻辑类已经继承了某个框架提供的基类,这时候你再想让它成为一个线程,就只能选择实现Runnable接口。而Runnable是一个接口,一个类可以实现多个接口,所以它提供了更大的灵活性。

其次,是任务与线程的解耦。实现Runnable接口的方式,将“任务(run()方法里的逻辑)”和“执行任务的线程(Thread对象)”分开了。这意味着你可以把同一个Runnable实例传递给多个Thread对象,让它们共享同一个任务逻辑,但每个线程独立运行。这对于资源共享和任务调度来说,是非常有用的。比如,你有一个数据处理任务,可以创建多个线程来并行处理,它们都使用同一个Runnable任务实例,但处理的数据片段不同。而继承Thread类的方式,任务逻辑是和线程本身紧密耦合在一起的,每个Thread实例都包含了它自己的任务逻辑,复用起来就没那么直接了。

我个人更倾向于使用Runnable,因为它更符合“面向接口编程”的思想,也避免了Java单继承的限制。在现代Java开发中,结合线程池(ExecutorService)来管理Runnable任务,更是标准实践,能更好地控制并发,避免资源耗尽。

如何管理和控制Java线程的生命周期?

线程的生命周期,可不是你启动了它就万事大吉那么简单。一个线程从诞生到消亡,会经历几个状态,我们作为开发者,需要知道如何去引导和控制它。

一个线程的生命周期大致分为:新建(New)可运行(Runnable)运行(Running)阻塞(Blocked)等待(Waiting)计时等待(Timed Waiting)终止(Terminated)

启动线程: 调用Thread对象的start()方法。注意,不是run()方法!start()方法会告诉JVM,为这个线程分配资源,并调用其内部的run()方法。如果直接调用run(),那它就只是一个普通的方法调用,不会创建新的线程。

暂停执行: Thread.sleep(long millis)。这个方法会让当前线程暂停指定毫秒数,进入计时等待状态。它不会释放锁,所以如果当前线程持有某个对象的锁,其他线程是无法获取这个锁的。

芦笋演示 芦笋演示

一键出成片的录屏演示软件,专为制作产品演示、教学课程和使用教程而设计。

芦笋演示 34 查看详情 芦笋演示

等待其他线程完成: thread.join()。当一个线程A调用另一个线程B的join()方法时,线程A会进入等待状态,直到线程B执行完毕或者等待时间到期(join(long millis))。这在需要等待某个后台任务完成后才能继续主流程的场景非常有用。

// 示例:join()的使用Thread worker = new Thread(() -> {    System.out.println("工人线程开始工作...");    try {        Thread.sleep(3000);    } catch (InterruptedException e) {        Thread.currentThread().interrupt();    }    System.out.println("工人线程工作完成。");}, "工人线程");worker.start();System.out.println("主线程等待工人线程完成...");try {    worker.join(); // 主线程等待工人线程结束} catch (InterruptedException e) {    Thread.currentThread().interrupt();}System.out.println("主线程继续执行,因为工人线程已经完成了。");

中断线程: thread.interrupt()。这是一种协作式机制,它并不会强制停止一个线程,而是向线程发送一个中断信号(设置中断标志位)。线程内部需要周期性地检查这个标志位(Thread.currentThread().isInterrupted()),或者在执行可中断操作(如sleep(), join(), wait())时捕获InterruptedException,然后根据业务逻辑决定是退出还是继续。

// 示例:中断线程Thread interruptibleThread = new Thread(() -> {    while (!Thread.currentThread().isInterrupted()) {        System.out.println("我还在努力工作...");        try {            Thread.sleep(1000);        } catch (InterruptedException e) {            System.out.println("我被中断了,准备退出!");            Thread.currentThread().interrupt(); // 重新设置中断标志,以便外层循环检查        }    }    System.out.println("我优雅地退出了。");}, "可中断线程");interruptibleThread.start();try {    Thread.sleep(3500); // 让它跑一会儿} catch (InterruptedException e) {    Thread.currentThread().interrupt();}interruptibleThread.interrupt(); // 发送中断信号

线程同步与协作: wait(), notify(), notifyAll()。这些方法必须在同步块(synchronized)中使用,并且是Object类的方法。它们用于线程间的通信和协作,让线程在特定条件下等待(释放锁),并在条件满足时被唤醒。

管理线程生命周期,尤其是中断和同步,是并发编程中非常容易出错的地方。记住,永远不要使用Thread.stop()suspend()resume()这些已废弃的方法,它们是线程不安全的,可能导致死锁或资源泄露。

在实际项目中,Java线程有哪些常见应用场景与最佳实践?

在实际的软件开发中,线程可不是为了炫技而存在的,它们解决的是实实在在的性能、响应性以及资源利用率问题。

常见应用场景:

后台任务处理: 这是最常见的场景。比如用户上传了一个大文件,你不可能让用户一直等着文件上传和处理完成。这时候就可以把文件处理的任务扔给一个后台线程去执行,主线程(通常是UI线程或请求处理线程)可以立即响应用户。像日志写入、数据备份、报表生成等,都属于这类。

异步操作: 当你需要调用一个耗时很长的外部服务(比如网络请求、数据库查询),又不想阻塞当前线程时,可以将其放在一个新线程中异步执行。结果可以通过回调或者Future/CompletableFuture来获取。这对于提升系统的吞吐量和响应速度非常关键。

并行计算: 对于一些可以拆分成独立子任务的计算密集型工作,比如大数据处理、图像渲染、科学计算等,可以利用多核CPU的优势,将任务分配给多个线程并行执行,显著缩短总执行时间。

定时任务: 使用ScheduledExecutorService可以很方便地创建定时执行或周期性执行的任务,比如每隔一小时同步一次数据,或者每天凌晨生成一份日报。

最佳实践:

优先使用线程池: 直接创建new Thread()在大多数生产环境中都是不推荐的。频繁地创建和销毁线程会带来很大的性能开销。使用ExecutorService(如ThreadPoolExecutor)来管理线程池,可以复用线程,控制并发线程的数量,避免系统资源耗尽。

import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.TimeUnit;public class ThreadPoolDemo {    public static void main(String[] args) {        // 创建一个固定大小的线程池,比如5个线程        ExecutorService executor = Executors.newFixedThreadPool(5);        for (int i = 0; i  { // 提交一个Runnable任务                System.out.println(Thread.currentThread().getName() + " 正在处理任务 " + taskNum);                try {                    Thread.sleep(500 + (long) (Math.random() * 500));                } catch (InterruptedException e) {                    Thread.currentThread().interrupt();                }                System.out.println(Thread.currentThread().getName() + " 完成任务 " + taskNum);            });        }        // 关闭线程池,等待所有任务执行完毕        executor.shutdown();        try {            if (!executor.awaitTermination(60, TimeUnit.SECONDS)) {                executor.shutdownNow(); // 强制关闭            }        } catch (InterruptedException e) {            executor.shutdownNow();            Thread.currentThread().interrupt();        }        System.out.println("所有任务提交完毕,线程池已关闭。");    }}

你看,通过线程池,我们不需要手动去管理每个线程的生命周期,把任务丢进去就行了,这大大简化了并发编程的复杂度。

关注线程安全: 当多个线程访问和修改共享数据时,必须采取同步措施(如synchronized关键字、ReentrantLockvolatile关键字、Atomic类等),否则会导致数据不一致或不可预测的行为。这是并发编程中最大的坑之一,需要投入大量精力去理解和实践。

避免死锁: 死锁是多线程编程中一个经典问题,当两个或多个线程在等待彼此释放资源时,就会发生死锁。设计时要尽量避免循环依赖的资源获取,或者使用定时锁来打破死锁条件。

合理设置线程优先级: 线程优先级只是给调度器一个提示,并不能保证高优先级线程一定先执行。在大多数情况下,让操作系统自行调度是最好的选择,过度依赖优先级可能会导致意想不到的行为。

总的来说,Java线程是构建高性能、响应式应用的基础,但它也带来了并发编程的复杂性。理解其核心机制、合理运用线程池、并始终将线程安全放在首位,是写出高质量并发代码的关键。

以上就是如何用Java创建和使用线程类 Java线程创建方式与示例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/242804.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 02:15:47
下一篇 2025年11月4日 02:20:11

相关推荐

  • 比特币交易记录如何查询_比特币交易记录查询方法详解

    比特币交易记录存储在区块链上,公开透明,任何人都可通过特定工具查询。本文详细介绍查询比特币交易记录的方法,帮助用户快速获取交易信息,适合新手和资深投资者。 一、使用区块链浏览器 1、选择可靠浏览器:访问Blockchair或Blockchain.com等知名区块链浏览器,确保数据准确。 2、输入交易…

    2025年12月9日
    000
  • 狗狗币合约怎样追加保证金_狗狗币合约保证金追加指南

    在狗狗币合约交易中,当市场行情向不利于您持仓的方向发展时,及时追加保证金是防止仓位被强制平仓的关键操作。这能有效帮助您管理风险,为您的交易策略争取更多的时间和空间。 理解追加保证金的核心目的 1、追加保证金最直接和重要的目的就是降低您的预估强平价格。当您向一个独立的仓位增加更多资金时,相当于提升了该…

    2025年12月9日
    000
  • FreeStyle Classic(FST币)是什么?怎么样?FST币技术架构、代币经济学级路线图介绍

    目录 什么是 FreeStyle Classic?技术架构和游戏玩法代币经济学(FST):供应、合约和效用披露且可验证的信息推断效用验证提示生态系统合作伙伴关系和平台集成最新动态和社区信号路线图和里程碑游戏推出节奏资产循环跨链适配生态系统联合营销风险与合规说明常问问题关键要点 freestyle c…

    2025年12月9日
    000
  • 一文解读:哪四大因素让以太坊(ETH)跑赢比特币(BTC)

    过去几周,加密市场出现了一个值得关注的趋势:以太坊(eth)在表现上显著跑赢了比特币(btc)。 根据摩根大通(JPMorgan)最新发布的研报,华尔街分析师们将这一现象归因于四大核心因素——ETF 结构优化、企业财务部的增持、监管层态度缓和,以及未来质押功能的潜在放开。这些因素不仅解释了以太坊的近…

    2025年12月9日
    000
  • 欧e交易所网格交易教学:两种网格策略操作与优劣势介绍

    目录 OKX 网格策略是什么OKX 网格策略特色OKX 网格策略限制OKX 网格策略开单教学现货网格合约网格结语 市场横盘震荡也能赚钱?透过交易机器人实现24 小时自动低买高卖,让你无需盯盘,就能每个月打造被动收入。 这篇文章会介绍OKX 网格策略,也探讨它的特色与限制。此外,我们也会以手机版App…

    2025年12月9日 好文分享
    000
  • BNB币价将于2025年创下历史新高

    ‍ BNB在2025年8月再次刷新历史价格纪录。据Coingecko数据显示,该代币于8月14日一度触及864美元。随后涨势不减,仅一周时间便在8月21日攀升至881美元,创下新的价格高峰。 BNB有望在2025年8月持续刷新高点 此前,BNB曾在7月底短暂达到855美元,接近当时的最高水平。这一走…

    2025年12月9日
    000
  • 什么因素让以太坊跑赢比特币?一文分析四大原因

    过去几周,以太坊(ETH)的表现显著优于比特币(BTC)。 根据摩根大通(JPMorgan)最新发布的研报,华尔街分析师团队将这一趋势归因于四大关键因素:ETF结构优化、企业财务部门的增持、监管对流动性质押代币态度的缓和,以及ETF实物赎回机制的获批。 这些驱动因素不仅解释了ETH近期的强势行情,也…

    2025年12月9日
    000
  • 什么是Omni Network(OMNI币)?OMNI价格预测2025、2026-2030年

    omni network(omni)是一个专为以太坊生态系统设计的区块链,其核心目标是整合所有以太坊的第二层(layer 2)扩展解决方案,即rollups,使其成为一个统一且互通的网络。在当前以太坊生态中,不同的rollups(如arbitrum、optimism、zksync等)各自为政,形成了…

    2025年12月9日
    000
  • 什么是Codatta(XNY币)?XNY代币经济学及价格预测2025、2026-2036年

    目录 摘要简介为什么您最近应该关注Codatta?Codatta 概述什么是Codatta (XNY)?以下是一些突出特点:Codatta 如何运作?关键数据类型实际应用数据资产化和主权XNY背后的技术团队与起源关于Codatta 的融资信息Codatta 的代币经济学分配明细:XNY 的发展前景和…

    2025年12月9日
    000
  • 什么是DEGEN?DEGEN价格预测:2025、2026-2030年

    目录 什么是DEGEN (DEGEN)?Degen如何运作当前市场状况影响DEGEN 价格的因素历史价格走势市值与成交量2025年展望Degen 值得买入吗?DEGEN 价格预测(2025-2030)2025 年DEGEN 价格预测2026 年DEGEN 价格预测2030 年DEGEN 价格预测未来…

    2025年12月9日
    000
  • OKB销毁后价格飙涨,涨势会持续多久?OKB币会突破300美元吗?

    OKB因其常规销毁计划的执行而引发市场广泛关注,其价格也随之出现显著上扬。这一现象并非偶然,而是其内在价值逻辑和通缩模型的直接体现。销毁机制通过从流通中永久移除一部分代币,有效减少了市场上的总供应量,当市场需求保持稳定或增长时,这种供需关系的变化往往会直接推动资产价格的提升。 欧易官网注册地址: 欧…

    2025年12月9日
    000
  • 比特币现金(BCH)是什么?和比特币有什么不同

    比特币现金(BCH)是比特币(BTC)的一个重要分支,它诞生于2017年8月1日的一次硬分叉事件。这次分叉的根本原因在于比特币社区内部对于如何解决网络扩容问题的长期争议。随着比特币用户和交易量的增长,其每个区块1MB的大小限制导致了网络拥堵、交易确认时间变长以及手续费用显著上涨,这与最初设想的“点对…

    2025年12月9日
    000
  • Token(代币)是什么?与Coin(币)有什么不同?

    “币”(Coin)和“代币”(Token)是两个经常被提及但又容易混淆的概念。尽管它们都以数字形式存在,并在区块链技术的基础上运行,但其底层技术、功能和创建方式却存在本质区别。简单来说,Coin是其自有独立区块链上的原生资产,如同一个国家的法定货币,是整个生态系统的基础燃料,用于激励网络参与者并支付…

    2025年12月9日
    000
  • 什么是Bio Protocol? 值得关注的五大DAO介绍

    目录 什么是Bio Protocol?Bio Protocol 上的BioAgents 是什么?Bio Protocol 如何运作?Bio Protocol 协议中值得关注的五大DAO1. VitaDAO – 长寿研究2. CerebrumDAO – 大脑健康与神经科学3. …

    2025年12月9日 好文分享
    000
  • 大白话解释一下什么是稳定币

    稳定币是价格锚定美元等资产的数字货币,旨在解决比特币等币种价格波动大的问题,主要通过法币抵押(如USDT、USDC)、加密资产超额抵押(如DAI)和算法调节三种机制维持稳定,成为交易所内的通用交易媒介和资产避险工具。 大白话来说,稳定币就是一种价格非常稳定的数字货币。它的目标就是让自己的价格尽量钉死…

    2025年12月9日
    000
  • tokens翻译成中文 tokens怎么读

    代币(Tokens)是基于现有区块链发行的数字凭证,依赖于以太坊等主链运行,不具备独立网络。与拥有自主区块链的原生币(如BTC、ETH)不同,代币如同运行在操作系统上的应用,依附于底层网络进行交易验证。 Tokens在中文里通常被翻译为代币,也有一个更偏向于技术和理论的翻译叫作通证。它的英文读音可以…

    2025年12月9日
    000
  • 什么是tokens?tokens怎么计算?

    Tokens是AI模型处理文本的基本单位,可为单词、字或标点;英文中1词约1-2个tokens,中文1字约1-3个tokens,因分词方式不同导致中英文token数量差异。 Tokens可以被理解为人工智能模型处理文本时的基本单位。模型在理解和生成语言时,并不是直接处理单词或字符,而是先将文本分解成…

    2025年12月9日
    000
  • Hyperliquid合约交易所 11人撑起年入11亿美元的去中心化币安

    目录 Hyperliquid究竟是什么?一个“看似去中心化的中心化交易所”为何能迅速超越dYdX等传统永续合约平台? 最新资讯显示,根据 DeFiLlama 的统计数据,Hyperliquid 协议在过去30天内产生的收入约为9563万美元,年化收入预估高达11.47亿美元。项目团队仅由11名成员组…

    2025年12月9日
    000
  • 什么是Lightchain AI?优缺点、未来发展介绍

    什么是Lightchain AI? Lightchain AI 是一项颠覆性技术,将区块链的去中心化架构与前沿人工智能能力深度融合,打造出性能更强、更安全的系统。与传统集中式AI不同,Lightchain AI 支持去中心化AI应用在可扩展且安全的节点网络中运行。 通过将模型训练、预测分析和复杂计算…

    2025年12月9日
    000
  • 比特币网站哪个好 全球比特币网站2025排名

    随着数字货币市场的持续发展,选择一个安全可靠、功能全面的比特币交易网站是每位投资者的首要任务。本文综合评估了全球主流平台的交易深度、安全性、用户体验及产品生态,为您提供一份2025年全球比特币网站的权威排名,旨在帮助您快速筛选出最适合您交易需求的平台。 全球比特币网站2025年综合排名 1. 币安 …

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信