单例模式线程池

方法一、使用静态内部类(线程安全、懒加载)

public class SingletonThreadPool {
    private ExecutorService  threadPool;

    private SingletonThreadPool() {
        threadPool = Executors.newCachedThreadPool();
    }

    private static class SingletonContainer {
        private static SingletonThreadPool instance = new SingletonThreadPool();
    }

    public static SingletonThreadPool getInstance() {
        return SingletonContainer.instance;
    }

    public ExecutorService getThreadPool() {
        return threadPool;
    }

}

方法二、使用枚举实现(JDK1.5+支持,《Effective Java》推荐方式)

相比于方法一,此种方式可避免序列化或反射破坏单例。

public enum SingletonThreadPool {
    INSTANCE;

    private ExecutorService threadPool;

    private SingletonThreadPool() {
        threadPool = Executors.newCachedThreadPool();
    }

    public ExecutorService getThreadPool() {
        return threadPool;
    }
}
以下是一个使用单例模式实现的线程池的C++示例: ```cpp #include <iostream> #include <vector> #include <queue> #include <thread> #include <mutex> #include <condition_variable> class ThreadPool { public: static ThreadPool& getInstance() { static ThreadPool instance; return instance; } void addTask(std::function<void()> task) { std::unique_lock<std::mutex> lock(mutex_); tasks_.push(task); condition_.notify_one(); } private: ThreadPool() { int numThreads = std::thread::hardware_concurrency(); for (int i = 0; i < numThreads; ++i) { threads_.emplace_back([this]() { while (true) { std::function<void()> task; { std::unique_lock<std::mutex> lock(mutex_); condition_.wait(lock, [this]() { return !tasks_.empty(); }); task = tasks_.front(); tasks_.pop(); } task(); } }); } } ~ThreadPool() { { std::unique_lock<std::mutex> lock(mutex_); stop_ = true; } condition_.notify_all(); for (std::thread& thread : threads_) { thread.join(); } } ThreadPool(const ThreadPool&) = delete; ThreadPool& operator=(const ThreadPool&) = delete; private: std::vector<std::thread> threads_; std::queue<std::function<void()>> tasks_; std::mutex mutex_; std::condition_variable condition_; bool stop_ = false; }; // 使用示例 void task1() { std::cout << "Task 1 executed" << std::endl; } void task2() { std::cout << "Task 2 executed" << std::endl; } int main() { ThreadPool& threadPool = ThreadPool::getInstance(); threadPool.addTask(task1); threadPool.addTask(task2); // 等待任务执行完成 std::this_thread::sleep_for(std::chrono::seconds(1)); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值