当前位置: 首页 > news >正文

【JAVA】封装多线程实现

系列文章目录

java知识点


文章目录

  • 系列文章目录
  • 👉前言
  • 👉一、封装的目标
  • 👉二、常见的封装方式及原理
  • 👉壁纸分享
  • 👉总结


👉前言

在 Java 中,封装多线程的原理主要围绕着将多线程相关的操作和逻辑进行抽象、隐藏底层细节,提供更简洁、易用和安全的接口供开发者使用。以下从封装的目标、常见的封装方式以及其背后的核心原理等方面进行详细解析。

博客将会介绍如何实现Unity优化协程。希望这篇博客对Unity的开发者有所帮助。
大家好,我是心疼你的一切,不定时更新Unity开发技巧,觉得有用记得一键三连哦。
欢迎点赞评论哦.下面就让我们进入正文吧 !


提示:以下是本篇文章正文内容,下面案例可供参考

👉一、封装的目标

简化使用:Java 原生的多线程编程涉及到很多复杂的操作,如线程的创建、启动、同步控制等。通过封装,可以提供简单易用的接口,让开发者无需深入了解底层细节就能方便地使用多线程功能。
提高安全性:多线程编程中存在着线程安全问题,如数据竞争、死锁等。封装可以在内部实现线程安全的机制,避免开发者在使用时犯错,提高程序的稳定性和安全性。
增强可维护性和可扩展性:将多线程逻辑封装在独立的模块中,使得代码结构更加清晰,便于维护和扩展。当需要更改多线程的实现方式时,只需修改封装模块的内部代码,而不会影响到使用该封装的其他部分。

👉二、常见的封装方式及原理

基于 Runnable 接口或 Callable 接口的封装
原理:Runnable 接口和 Callable 接口是 Java 中定义线程任务的基础接口。通过将线程任务封装在实现了这两个接口的类中,可以将任务的定义和线程的管理分离开来。Runnable 接口中的 run() 方法没有返回值,而 Callable 接口中的 call() 方法可以有返回值,适用于需要获取线程执行结果的场景。

代码如下:

import java.util.concurrent.*;

// 实现 Runnable 接口的任务类
class MyRunnableTask implements Runnable {
    @Override
    public void run() {
        System.out.println("Runnable 任务正在执行,线程名: " + Thread.currentThread().getName());
    }
}

// 实现 Callable 接口的任务类
class MyCallableTask implements Callable<String> {
    @Override
    public String call() throws Exception {
        return "Callable 任务执行结果,线程名: " + Thread.currentThread().getName();
    }
}

public class ThreadTaskWrapper {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        // 使用 Runnable 任务
        Thread runnableThread = new Thread(new MyRunnableTask());
        runnableThread.start();

        // 使用 Callable 任务
        ExecutorService executor = Executors.newSingleThreadExecutor();
        Future<String> future = executor.submit(new MyCallableTask());
        String result = future.get();
        System.out.println(result);
        executor.shutdown();
    }
}

线程池的封装
原理:线程池是一种管理和复用线程的机制,它可以避免频繁创建和销毁线程带来的性能开销。Java 提供了 ExecutorService 接口和相关的实现类(如 ThreadPoolExecutor、Executors 工具类)来创建和管理线程池。通过封装线程池,可以提供统一的接口来提交任务,同时管理线程的生命周期和资源分配。

代码如下:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

// 封装线程池的类
class ThreadPoolWrapper {
    private final ExecutorService executor;

    public ThreadPoolWrapper(int poolSize) {
        this.executor = Executors.newFixedThreadPool(poolSize);
    }

    public void submitTask(Runnable task) {
        executor.submit(task);
    }

    public void shutdown() {
        executor.shutdown();
    }
}

// 使用封装的线程池
public class Main {
    public static void main(String[] args) {
        ThreadPoolWrapper threadPool = new ThreadPoolWrapper(3);
        for (int i = 0; i < 5; i++) {
            final int taskId = i;
            threadPool.submitTask(() -> {
                System.out.println("任务 " + taskId + " 正在执行,线程名: " + Thread.currentThread().getName());
            });
        }
        threadPool.shutdown();
    }
}

请添加图片描述

👉壁纸分享

请添加图片描述


👉总结

本次总结的就是【JAVA】封装多线程实现, 有需要会继续增加功能
如能帮助到你,就帮忙点个赞吧,三连更好哦,谢谢
你的点赞就是对博主的支持,有问题记得留言评论哦!
不定时更新Unity开发技巧,觉得有用记得一键三连哦。么么哒!

相关文章:

  • 【WebGL】fbo双pass案例
  • 《AI与NLP:开启元宇宙社交互动新纪元》
  • ue5地面上出现preview字样
  • 服务可用性评价指标
  • 第二届粤港澳大湾区数字经济与人工智能国际学术会议(DEAI 2025)
  • C++ MFC添加RichEditControl控件后,程序启动失败
  • 从零搭建微服务项目Pro(第1-1章——Quartz实现定时任务模块)
  • C++:std::thread、条件变量与信号量
  • 【网络】高级IO——Reactor版TCP服务器
  • 【学习笔记】Cadence电子设计全流程(二)原理图库的创建与设计(5-7)
  • 【JT/T 808协议】808 协议开发笔记 ② ( 终端注册 | 终端注册应答 | 字符编码转换网站 )
  • MongoDB应用设计调优
  • 【Leetcode 每日一题 - 扩展】1512. 好数对的数目
  • 鸿蒙NEXT应用App测试-专项测试(DevEco Testing)
  • 【Elasticsearch】同一台服务器部署集群
  • Java IO 设计模式总结
  • Plant Simulation培训教程-机器人3D仿真模块
  • C# AOT技术测试
  • DeepSeek 全面分析报告
  • 大语言模型微调的公开JSON数据
  • 万里云端遇见上博--搭乘“上博号”主题飞机体验记
  • 4月外汇储备增加410亿美元,黄金储备连续6个月增加
  • 成立6天的公司拍得江西第三大水库20年承包经营权,当地回应
  • 李云泽:小微企业融资协调工作机制已发放贷款12.6万亿元
  • 中国公民免签赴马来西亚的停留天数如何计算?使馆明确
  • 上海虹桥高铁站拦门事件反转,谁在带偏网友?