首页 > 编程语言 >全面详解Java并发编程:从基础到高级应用

全面详解Java并发编程:从基础到高级应用

时间:2024-05-27 15:33:07浏览次数:30  
标签:Java concurrent 编程 util 并发 详解 线程 java public

全面详解Java并发编程:从基础到高级应用

Java并发编程是Java开发中一个非常重要的领域,涉及多线程编程技术,用于提高程序的性能和响应能力。并发编程在多核处理器上特别有用,因为它可以同时执行多个任务,从而提高应用程序的效率。以下是对Java并发编程的详细讲解,涵盖基本概念、线程管理、同步机制、高级并发工具和最佳实践。

1. 基本概念

1.1 进程和线程
  • 进程:是程序在操作系统中的一次执行实例。每个进程都有独立的内存空间。
  • 线程:是进程中的一个执行路径。一个进程可以包含多个线程,这些线程共享进程的内存空间。
1.2 多线程

多线程允许程序并发执行多个任务,适用于需要处理多个独立任务的场景,如服务器处理多个客户端请求。

2. 线程管理

2.1 创建线程

在Java中,可以通过以下三种方式创建线程:

a. 继承Thread类

public class MyThread extends Thread {
    public void run() {
        System.out.println("Thread is running");
    }
    
    public static void main(String[] args) {
        MyThread thread = new MyThread();
        thread.start();
    }
}

b. 实现Runnable接口

public class MyRunnable implements Runnable {
    public void run() {
        System.out.println("Thread is running");
    }

    public static void main(String[] args) {
        Thread thread = new Thread(new MyRunnable());
        thread.start();
    }
}

c. 实现Callable接口并使用FutureTask

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

public class MyCallable implements Callable<String> {
    public String call() throws Exception {
        return "Thread is running";
    }

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        MyCallable callable = new MyCallable();
        FutureTask<String> futureTask = new FutureTask<>(callable);
        Thread thread = new Thread(futureTask);
        thread.start();
        
        System.out.println(futureTask.get());
    }
}
2.2 线程的生命周期

线程的生命周期包括以下几个状态:

  • 新建(New):线程对象被创建,但未启动。
  • 就绪(Runnable):线程已经启动并等待CPU时间片。
  • 运行(Running):线程正在执行代码。
  • 阻塞(Blocked):线程因等待资源而暂停执行。
  • 死亡(Terminated):线程执行完毕或因异常退出。

3. 同步机制

为了防止多个线程同时访问共享资源而引起的数据不一致问题,Java提供了同步机制。

3.1 同步方法和同步块

同步方法

public synchronized void synchronizedMethod() {
    // critical section
}

同步块

public void synchronizedBlock() {
    synchronized (this) {
        // critical section
    }
}

想深入学习Synchronized,请参考深入解析 Java 中的 Synchronized:原理、实现与性能优化

3.2 volatile关键字

volatile关键字用于确保变量的可见性,即当一个线程修改变量值时,其他线程立即看到最新的值。

private volatile boolean flag = true;

想深入学习volatile关键字,请参考深入理解java中的volatile关键字

3.3 显式锁(ReentrantLock)

ReentrantLock提供了更高级的同步特性,如公平锁、可中断锁等。

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class MyLock {
    private final Lock lock = new ReentrantLock();

    public void perform() {
        lock.lock();
        try {
            // critical section
        } finally {
            lock.unlock();
        }
    }
}

4. 高级并发工具

Java的java.util.concurrent包提供了丰富的并发工具类。

4.1 Executor框架
Executor框架用于管理线程池和执行任务,主要接口和类有ExecutorService、Executors和ThreadPoolExecutor。

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

public class MyExecutor {
    public static void main(String[] args) {
        ExecutorService executor = Executors.newFixedThreadPool(5);
        for (int i = 0; i < 10; i++) {
            executor.submit(() -> {
                System.out.println("Task is running");
            });
        }
        executor.shutdown();
    }
}
4.2 并发集合

并发集合类提供了线程安全的集合,如ConcurrentHashMap、CopyOnWriteArrayList等。

import java.util.concurrent.ConcurrentHashMap;

public class MyConcurrentMap {
    public static void main(String[] args) {
        ConcurrentHashMap<String, String> map = new ConcurrentHashMap<>();
        map.put("key", "value");
        System.out.println(map.get("key"));
    }
}
4.3 并发工具类

java.util.concurrent包还提供了许多其他并发工具类,如CountDownLatch、CyclicBarrier、Semaphore、Exchanger等。

import java.util.concurrent.CountDownLatch;

public class MyCountDownLatch {
    public static void main(String[] args) throws InterruptedException {
        CountDownLatch latch = new CountDownLatch(3);
        
        for (int i = 0; i < 3; i++) {
            new Thread(() -> {
                System.out.println("Task completed");
                latch.countDown();
            }).start();
        }
        
        latch.await();
        System.out.println("All tasks completed");
    }
}

5. 最佳实践

5.1 避免死锁

通过锁顺序、超时机制、死锁检测等方法避免死锁。

5.2 使用线程池

使用线程池复用线程,避免频繁创建和销毁线程带来的性能开销。

5.3 减少锁粒度

尽量减少锁的粒度,以提高并发性能。

5.4 避免共享可变状态

尽量避免共享可变状态,使用不可变对象或线程本地存储(ThreadLocal)来隔离线程的状态。

5.5 使用高效的并发工具

利用java.util.concurrent包中的高级并发工具,减少手动管理线程和同步的复杂性。

总结

Java并发编程提供了强大的工具和框架,帮助开发者有效管理多线程任务,提升应用程序性能。理解并掌握基本概念、线程管理、同步机制和高级并发工具,并遵循最佳实践,可以编写出高效、安全、可靠的并发程序。

标签:Java,concurrent,编程,util,并发,详解,线程,java,public
From: https://blog.csdn.net/qq_38411796/article/details/139227270

相关文章

  • 图形化编程题:根据身份证号码识别是否优先选择火车下铺,Scratch编程实现代码--电子学会2
    今天做了一下2024.3的电子学会的2道二级考级题,三道三级考级题,2道四级考级题。整体感觉越来越靠近真实的做软件了。里面应用到排序、自定义模块(这相当于c++的函数,java的方法)、校验输入是否全是数字、标识符等,感觉这次编程题整体难度比之前要提升了一丢丢。按理像我这种写了10......
  • 【开源】史上最全的JAVA面试题总结
    史上最全的JAVA面试题总结为什么要做这件事情前言JAVA基础开发框架springSpringMVCmybatisdubbospringbootspringcloudnacos数据库mysqloracle缓存redismongodbElasticSearch消息队列rabbitmqrocketmqkafka监控prometheusgraylogzabbix工具篇tcpdumpgitjenkins容器......
  • Java实验六: Java流式编程与网络程序设计(头歌)
    一、字节输入/输出流实现数据的保存和读取packagestep1;importjava.io.*;importjava.util.*;publicclassSortArray{publicstaticvoidmain(String[]args){/**********Begin**********///创建保存整型数据的数组(数组大小10)......
  • java 加载bean 2
    @RequiredArgsConstructor@Component@RequestMapping("/timeLineData")publicclassTimeLineData{ finalCustomSqlServicecustomSqlService; @Inner(false) @PostMapping("/setTimeLine") voidsetTimeLine(@RequestBodyMap<String,Obj......
  • 1.说说你学过的编程语言。2.你了解过的编程工具。
    1.我学过的编程语言有java和c语言。Java的优势:跨平台性:Java的“一次编写,到处运行”的特性使其具有出色的跨平台性。这主要得益于Java虚拟机(JVM)的存在,它使得Java程序可以在任何支持JVM的平台上运行。自动内存管理:Java提供了垃圾回收机制,自动管理内存,减少了程序员手动管理内存的......
  • JavaScript 控制网页行为
    UI框架Ant-Design:阿里巴巴出品,基于React的UI框架ElementUI、iview、ice:饿了么出品,基于Vue的UI框架Bootstrap:Twitter推出的一个用于前端的开源工具包AmazeUI:又叫“妹子UI”,一款HTML5跨屏前端框架1.基本使用1.1.引入JavaScript内部标签使用<script>//........
  • Java 进程 CPU 占用过高问题排查
    1.Java进程CPU占用过高问题排查1.1.运行环境1.2.定位CPU占用高的进程1.3.定位CPU占用高的线程1.4.将线程ID转换为十六进制1.5.找到线程对应的栈信息1.5.1.使用jstack1.5.2.使用jcmd1.5.3.使用arthas1.5.4.使用jattach1.Java进程CPU......
  • java —— 异常处理
    一、认识异常java中的异常大致分为三类:编译错误、逻辑错误、运行异常。其中编译错误和逻辑错误通常手动更改即可,运行异常是异常处理的主要内容。java中的异常全部继承自Exception类,其常见的子类如下:查看异常,例如:二、异常处理异常处理分为捕获异常和抛出异常,捕获异常......
  • Java EE-Spring AOP 面向切面编程
    SpringAOPhttps://www.cnblogs.com/joy99/p/10941543.html超级详细版:Chapter 6. 使用Spring进行面向切面编程(AOP)AOP原理面向切面(AspectOrientProgramming)面向切面编程,是面向对象编程(OOP)的一种补充。在Java程序自上而下处理主业务时,也会经常处理一些和主......
  • java如何创建Class对象?
    请思考一个问题:如果你想在java程序运行时获得某个类的信息,你会怎么办?首先要获得该类的Class对象,然后才可以通过Class类中的方法来获得与该Class对象相对应的类的信息。有3种方法来获得类的Class对象:1.用Class类的forName()方法。例如:Class.forName("java.lang.String");    ......