博客
关于我
Netty工作笔记0004---BIO简介,介绍说明
阅读量:794 次
发布时间:2023-02-14

本文共 1601 字,大约阅读时间需要 5 分钟。

线程池在Java中是一个非常重要的工具,它通过将任务分割到多个工作线程中,从而实现多线程并发。然而,使用线程池并不能真正提升程序的性能,反而只是让并发实现变得更加容易。

在Java程序中,线程池可以通过ThreadPoolExecutor来实现。要使用线程池,首先需要创建一个线程池实例:

ExecutorService executorService = new ThreadPoolExecutor(2, 5, 10, TimeUnit.SECONDS, new LinkedBlockingQueue<>());

接下来,可以提交任务到线程池中:

executorService.submit(new Runnable() {    public void run() {        System.out.println("这是一个运行在线程池中的任务");    }});

线程池的主要优势在于它可以自动管理线程的生命周期,包括线程的启动、停止和故障处理。然而,线程池并不会显著提高程序的性能,因为线程的 overhead 也会带来额外的资源消耗。

如果需要实现某些特定的并发任务,可以考虑手动管理线程。例如,如果需要监听一个特定的端口,可以创建一个线程来侦听该端口:

public class PortListener extends Thread {    public PortListener(int port) {        this.port = port;    }        int port;        public void run() {        try {            ServerSocket serverSocket = new ServerSocket(port);            while (true) {                Socket socket = serverSocket.accept();                // 处理连接                System.out.println("连接到端口" + port + "成功");            }        } catch (IOException e) {            System.out.println("端口监听失败:" + e.getMessage());        }    }}

然后,启动该线程:

new PortListener(6666).start();

当线程运行时,会监听指定的端口,并返回对应的Socket对象:

public class PortListener {    public static void main(String[] args) {        try {            ServerSocket serverSocket = new ServerSocket(6666);            while (true) {                Socket socket = serverSocket.accept();                System.out.println("连接到端口6666成功");                // 处理客户端连接            }        } catch (IOException e) {            System.out.println("端口监听失败:" + e.getMessage());        }    }}

通过上述代码,可以实现一个简单的端口监听服务器。这个例子展示了如何在Java中手动创建线程来实现并发任务。

转载地址:http://dncfk.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Netty工作笔记0021---NIO编写,快速入门---编写服务器
查看>>
Netty工作笔记0022---NIO快速入门--编写客户端
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0026---NIO 网络编程应用--群聊系统1---编写服务器1
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
查看>>
Netty工作笔记0029---NIO 网络编程应用--群聊系统4--客户端编写2
查看>>
Netty工作笔记0030---NIO与零拷贝原理剖析
查看>>
Netty工作笔记0031---NIO零拷贝应用案例
查看>>
Netty工作笔记0032---零拷贝AIO内容梳理
查看>>
Netty工作笔记0033---Netty概述
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0035---Reactor模式图剖析
查看>>
Netty工作笔记0036---单Reactor单线程模式
查看>>
Netty工作笔记0037---主从Reactor多线程
查看>>
Netty工作笔记0038---Netty模型--通俗版
查看>>
Netty工作笔记0039---Netty模型--详细版
查看>>