Java并发编程

Java并发编程是Java语言中的一个重要特性,它允许多个线程同时执行,从而提高程序的性能。在多核CPU的时代,并发编程已经成为了程序员必备的技能之一。本文将从Java并发编程的基本概念入手,介绍线程的创建和管理、同步机制、线程池等技术,并结合实际案例进行讲解。

一、线程的创建和管理

在Java中,可以通过继承Thread类或实现Runnable接口来创建线程。继承Thread类的方式比较简单,但是不能继承其他类;实现Runnable接口的方式比较灵活,可以将Runnable对象传给Thread类的构造函数来创建线程。在创建线程后,可以通过start()方法启动线程,通过join()方法等待线程结束。

二、同步机制

在多线程环境下,为了保证数据的一致性和完整性,需要使用同步机制来控制线程的执行顺序。Java提供了synchronized关键字和Lock接口来实现同步。synchronized关键字可以修饰方法或代码块,当一个线程获得锁后,其他线程必须等待锁释放才能继续执行。Lock接口提供了更灵活的同步方式,可以通过lock()和unlock()方法来获取和释放锁。

三、线程池

线程池是一种管理线程的技术,它可以复用已存在的线程,减少线程创建和销毁的开销。Java提供了ExecutorService接口来实现线程池,其中ThreadPoolExecutor类是最常用的实现类。可以通过构造函数传入核心线程数、最大线程数、空闲线程存活时间等参数来创建线程池。线程池中的线程可以通过execute()方法提交任务,通过shutdown()方法关闭线程池。

四、案例分析

下面是一个使用线程池实现的简单Web服务器示例:

复制代码
import java.io.*;
import java.net.*;
import java.util.concurrent.*;

public class WebServer {
   
    private ExecutorService pool;
    private ServerSocket server;

    public WebServer(int port, int poolSize) throws IOException {
   
        pool = Executors.newFixedThreadPool(poolSize);
        server = new ServerSocket(port);
    }

    public void start() throws IOException {
   
        while (true) {
   
            Socket connection = server.accept();
            pool.execute(new Handler(connection));
        }
    }

    private static class Handler implements Runnable {
   
        private Socket connection;

        public Handler(Socket connection) {
   
            this.connection = connection;
        }

        public void run() {
   
            try {
   
                InputStream input = connection.getInputStream();
                OutputStream output = connection.getOutputStream();
                PrintWriter writer = new PrintWriter(output, true);
                BufferedReader reader = new BufferedReader(new InputStreamReader(input));
                String line;
                while ((line = reader.readLine()) != null) {
   
                    writer.println("HTTP/1.1 200 OK");
                    writer.println("Content-Type: text/html");
                    writer.println("");
                    writer.println("<html><body><h1>Hello, world!</h1></body></html>");
                }
            } catch (IOException e) {
   
                e.printStackTrace();
            );
        }
    }
}

在这个示例中,Web服务器使用了线程池来处理客户端的请求。当接收到一个请求时,会创建一个新的Handler对象,并将其提交给线程池执行。Handler对象负责读取请求数据,并将响应数据发送回客户端。由于使用了线程池,服务器能够同时处理多个请求,提高了性能。

相关推荐
SelectDB2 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
Flittly3 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了3 小时前
Java 生成二维码解决方案
java·后端
人活一口气8 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP9 小时前
Vibe Coding -- 完整项目案例实操
java
荣码9 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing9 小时前
Google第三方授权登录
java·后端·程序员
明月光81810 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑19 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯20 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式