一个基于线程池技术的简单web服务器

本文介绍了一个基于线程池技术的简单Web服务器实现,该服务器能够展示图片。代码包括ThreadPool接口、DefaultThreadPool类、SimpleHttpServer类以及启动类ServerMain。在实现中,注意到了《java并发编程的艺术》第四章中的一个勘误,指出在写入HTTP响应时,out.flush()应该在写入数据之前执行,以避免出现'net:ERR_INVALID_HTTP_RESPONSE'错误。
摘要由CSDN通过智能技术生成

写一个基于多线程的web服务器,能提供展示图片的功能,代码如下:

接口 ThreadPool

/**
 * @author chendong
 * @date 2019/9/7 12:54
 */
public interface ThreadPool<Job extends Runnable> {

    // 执行一个job,这个Job需要实现Runnable
    void execute(Job job);

    // 关闭线程池
    void shutdown();

    // 增加工作者线程
    void addWorkers(int num);

    //  减少工作者线程
    void removeWorkers(int num);

    // 得到正在等待执行的任务数量
    int getJobSize();

}

类DefaultThreadPool

import javafx.concurrent.Worker;

import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * @author chendong
 * @date 2019/9/7 13:06
 */
public class DefaultThreadPool<Job extends Runnable> implements ThreadPool<Job> {

    // 线程池最大限制数
    private static final int MAX_WORKER_NUMBERS = 10;
    // 线程池默认的数量
    private static final int DEFAULT_WORKER_NUMBERS = 5;
    // 线程池最小的数量
    private static final int MIN_WORKER_NUMBERS = 1;

    // 这是一个工作列表,将会向里面插入工作
    private final LinkedList<Job> jobs = new LinkedList<Job>();
    // 工作者列表
    private final List<Worker> workers = Collections.synchronizedList(new ArrayList<Worker>());
    // 工作者线程的数量
    private int workerNum = DEFAULT_WORKER_NUMBERS;
    // 线程编号的生成
    private AtomicInteger threadNum = new AtomicInteger();

    // 初始化线程工作者
    private void initializeWorkers(int num){
        for(int i = 0; i < num; i++){
            Worker worker = new Worker();
            workers.add(worker);
            Thread thread = new Thread(worker, "ThreadPool-WOrker-" + threadNum.incrementAndGet());
            thread.start();
        }

    }

    public DefaultThreadPool(){
        initializeWorkers(DEFAULT_WORKER_NUMBERS);
    }

    public DefaultThreadPool(int num){
        workerNum = num > MAX_WORKER_NUMBERS ? MAX_WORKER_NUMBERS : num < MIN_WORKER_NUMBERS ? MIN_WORKER_NUMBERS : num;
        initializeWo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值