首页 > 编程语言 >【JUC编程】JUC 多线程基础全面解析(速食版,25年后更新专栏)

【JUC编程】JUC 多线程基础全面解析(速食版,25年后更新专栏)

时间:2024-12-26 23:26:57浏览次数:5  
标签:速食 JUC util 并发 线程 println new 多线程

这篇文章就多个方面简单涉及一些内容,到2025年我会更新并发编程这个专栏。计划在过年之前更新完,都是从基础到工作中常用(以及可能涉及到)的知识点,有些内容这篇文章没有提及。
希望大家可以多多支持、关注一下!

文章目录

JUC 多线程基础全面解析

Java 并发工具包(Java Util Concurrent,简称 JUC)是 Java 提供的一套强大的并发编程工具,主要用于简化多线程编程,提升并发程序的性能和可靠性。本文将从以下几个方面全面解析 JUC 的基础内容:


一、线程与并发基础

1. 什么是线程?

线程是 CPU 调度的最小单元。一个线程是一个独立的执行路径,可以与其他线程共享进程内的资源。

2. 并发与并行的区别
  • 并发(Concurrency):在同一时间间隔内处理多个任务。
  • 并行(Parallelism):在同一时刻执行多个任务。
3. Java 线程的基本创建方式
  • 继承 Thread

    class MyThread extends Thread {
        @Override
        public void run() {
            System.out.println("Thread running");
        }
    }
    new MyThread().start();
    
  • 实现 Runnable 接口

    class MyRunnable implements Runnable {
        @Override
        public void run() {
            System.out.println("Runnable running");
        }
    }
    new Thread(new MyRunnable()).start();
    
  • 使用 CallableFuture

    import java.util.concurrent.Callable;
    import java.util.concurrent.FutureTask;
    
    Callable<Integer> task = () -> {
        return 123;
    };
    FutureTask<Integer> futureTask = new FutureTask<>(task);
    new Thread(futureTask).start();
    System.out.println(futureTask.get());
    

二、JUC 核心组件

1. 线程池

线程池是 JUC 提供的一个重要工具,用于复用线程以减少线程创建和销毁的开销。

  • 线程池创建方式

    import java.util.concurrent.Executors;
    import java.util.concurrent.ExecutorService;
    
    ExecutorService pool = Executors.newFixedThreadPool(5);
    pool.execute(() -> System.out.println("Task executed"));
    pool.shutdown();
    
  • 常见线程池类型

    • FixedThreadPool:固定大小的线程池。
    • CachedThreadPool:动态扩展的线程池。
    • SingleThreadExecutor:单线程池。
    • ScheduledThreadPool:支持定时任务。
2. 锁机制

JUC 提供了更高级的锁,代替传统的 synchronized

  • ReentrantLock

    import java.util.concurrent.locks.ReentrantLock;
    
    ReentrantLock lock = new ReentrantLock();
    
    lock.lock();
    try {
        System.out.println("Critical section");
    } finally {
        lock.unlock();
    }
    
  • ReadWriteLock 读写锁允许多个读线程同时访问,但写线程独占。

    import java.util.concurrent.locks.ReentrantReadWriteLock;
    
    ReentrantReadWriteLock rwLock = new ReentrantReadWriteLock();
    
    rwLock.readLock().lock();
    try {
        System.out.println("Reading");
    } finally {
        rwLock.readLock().unlock();
    }
    
3. 并发集合

JUC 提供了线程安全的集合类。

  • ConcurrentHashMap:高效的线程安全哈希表。
  • CopyOnWriteArrayList:适用于读多写少的场景。
  • BlockingQueue:支持线程间安全通信的队列。

三、线程间通信工具

1. CountDownLatch

计数器,等待多个线程完成任务。

import java.util.concurrent.CountDownLatch;

CountDownLatch latch = new CountDownLatch(3);

new Thread(() -> {
    System.out.println("Task 1");
    latch.countDown();
}).start();

latch.await();
System.out.println("All tasks completed");
2. CyclicBarrier

线程到达屏障后一起执行。

import java.util.concurrent.CyclicBarrier;

CyclicBarrier barrier = new CyclicBarrier(3, () -> System.out.println("Barrier reached"));

new Thread(() -> {
    System.out.println("Task 1");
    barrier.await();
}).start();
3. Semaphore

控制线程并发数。

import java.util.concurrent.Semaphore;

Semaphore semaphore = new Semaphore(2);

new Thread(() -> {
    semaphore.acquire();
    System.out.println("Task running");
    semaphore.release();
}).start();

四、原子操作类

JUC 提供了一些高效的原子操作类,避免使用锁的开销。

  • AtomicInteger

    import java.util.concurrent.atomic.AtomicInteger;
    
    AtomicInteger count = new AtomicInteger(0);
    count.incrementAndGet();
    
  • AtomicReference

    import java.util.concurrent.atomic.AtomicReference;
    
    AtomicReference<String> ref = new AtomicReference<>("A");
    ref.compareAndSet("A", "B");
    

五、并发工具的使用场景和建议

  1. 线程池:适用于需要频繁创建和销毁线程的场景。
  2. :在读多写少场景下,优先考虑 ReadWriteLock
  3. 并发集合:推荐在多线程环境下使用。
  4. 线程间通信CountDownLatchCyclicBarrier 适合多线程协作。

六、总结

JUC 是 Java 提供的一套强大的并发工具,它简化了多线程编程的复杂性,同时提供了高效、安全的解决方案。通过合理使用线程池、锁机制、并发集合以及线程通信工具,我们可以更高效地开发并发程序。在实际开发中,应根据具体场景选择合适的工具,以保证性能与安全性。


博客主页: 总是学不会.

标签:速食,JUC,util,并发,线程,println,new,多线程
From: https://blog.csdn.net/m0_70871140/article/details/144679954

相关文章

  • Java多线程处理文件详解与代码示例
    在Java编程中,文件处理是一项常见的任务。当需要处理大量文件或处理文件的时间较长时,单线程的处理方式可能会显得效率低下。为了提高文件处理的效率,我们可以使用多线程技术。本文将详细介绍如何使用Java多线程来处理文件,并提供一个详细的代码示例,该示例可以直接运行。一、多线程处......
  • MySQL的MTS(多线程复制)和GC(组提交)
    开启MySQL的MTS(多线程复制)和GC(组提交)的主要参数如下:MTS(多线程复制)参数:slave_parallel_workers:设置从库上可以并行执行的线程数量。例如:slave_parallel_workers=8slave_parallel_type:设置从库并行复制的类型,有两个选项:DATABASE:基于库级别的并行复制。LOGICAL_CLOCK:基......
  • Java多线程第三篇-多线程的代码相关案例
    文章目录一.单例模式1.1饿汉模式1.2懒汉模式1.3指令重排序1.4解决方法volatile二.阻塞队列2.1模拟实现阻塞队列(生产者消费者模型)三.定时器(日常开发常见的组建)3.1创建并模拟定时器实现四.线程池4.1线程池的构造方法的使用4.2模拟实现线程池五.锁策略(特点)5.......
  • 多线程 Worker
    多线程Worker一些异步处理的任务,可以放置于Worker中运行,待运行结束后,再把结果返回到小程序主线程。Worker运行于一个单独的全局上下文与线程中,不能直接调用主线程的方法。Worker与主线程之间的数据传输,双方使用Worker.postMessage()来发送数据,Worker.onMessage()来接收......
  • C#队列、多线程根据URL下载文件
    ///<summary>///下载辅助类///</summary>publicclassDownFileHelper{///<summary>///构造函数///</summary>staticDownFileHelper(){Start();}privatestaticobjectlockObject=newobject();......
  • 高级java每日一道面试题-2024年12月23日-并发篇-多线程有什么用 ?
    如果有遗漏,评论区告诉我进行补充面试官:多线程有什么用?我回答:多线程编程是Java中非常重要的一个概念,它允许程序在同一时间执行多个任务。在现代计算机系统中,多线程技术的应用可以极大地提升应用程序的性能、响应速度以及资源利用率。以下是关于多线程用途的详细解......
  • Java多线程、线程池介绍及多线程间的协同
    Java多线程是Java编程中的一个核心概念,它允许程序同时执行多个任务,从而提高程序的执行效率和响应速度。下面我将从线程的创建、线程的状态管理、线程的协作、线程池的使用、同步机制的实现以及并发控制的方法等几个方面来详细介绍Java多线程。一、线程的创建在Java中,创建线程......
  • 【多线程】原子类
    JDK原子类基于CAS轻量级原子操作实现,使得程序运行效率变得更高。(1)基本原子类基本原子类的功能是通过原子方式更新Java基础类型变量的值。基本原子类主要包括以下三个:AtomicInteger:整型原子类。AtomicLong:长整型原子类。AtomicBoolean:布尔型原子类。(2)数组原子类数组原子类的功......
  • 在.NET Core中使用异步多线程高效率的处理大量数据的一种解决方案
    目录一、引言二、假设场景三、解决方案四、示例代码一、引言处理大量数据是一个常见的需求,传统的同步处理方式往往效率低下,尤其是在数据量非常大的情况下。本篇将介绍一种高效的多线程异步处理大数据量的方法,通过边处理边消费的方式,极大地提高了处理效率,并且减少了内存开销。这......
  • 多线程-锁-写锁(独占锁)/读锁(共享锁)
    一个资源能够被多个读线程访问,或者被一个写线程访问,但是不能同时存在读写线程。特点        可重入        读写分离无锁无序→加锁→读写锁演变classMyResource{Map<String,String>map=newHashMap<>();//=====ReentrantLock等价于=====s......