<i id='sUiNQ'><tr id='sUiNQ'><dt id='sUiNQ'><q id='sUiNQ'><span id='sUiNQ'><b id='sUiNQ'><form id='sUiNQ'><ins id='sUiNQ'></ins><ul id='sUiNQ'></ul><sub id='sUiNQ'></sub></form><legend id='sUiNQ'></legend><bdo id='sUiNQ'><pre id='sUiNQ'><center id='sUiNQ'></center></pre></bdo></b><th id='sUiNQ'></th></span></q></dt></tr></i><div id='sUiNQ'><tfoot id='sUiNQ'></tfoot><dl id='sUiNQ'><fieldset id='sUiNQ'></fieldset></dl></div>
    <bdo id='sUiNQ'></bdo><ul id='sUiNQ'></ul>
    <tfoot id='sUiNQ'></tfoot>
  1. <legend id='sUiNQ'><style id='sUiNQ'><dir id='sUiNQ'><q id='sUiNQ'></q></dir></style></legend>

      <small id='sUiNQ'></small><noframes id='sUiNQ'>

      Python 使用threading+Queue实现线程池示例

      时间:2023-12-16

            <tbody id='gNNUf'></tbody>

        1. <small id='gNNUf'></small><noframes id='gNNUf'>

            <bdo id='gNNUf'></bdo><ul id='gNNUf'></ul>

            <i id='gNNUf'><tr id='gNNUf'><dt id='gNNUf'><q id='gNNUf'><span id='gNNUf'><b id='gNNUf'><form id='gNNUf'><ins id='gNNUf'></ins><ul id='gNNUf'></ul><sub id='gNNUf'></sub></form><legend id='gNNUf'></legend><bdo id='gNNUf'><pre id='gNNUf'><center id='gNNUf'></center></pre></bdo></b><th id='gNNUf'></th></span></q></dt></tr></i><div id='gNNUf'><tfoot id='gNNUf'></tfoot><dl id='gNNUf'><fieldset id='gNNUf'></fieldset></dl></div>
                <tfoot id='gNNUf'></tfoot>

                <legend id='gNNUf'><style id='gNNUf'><dir id='gNNUf'><q id='gNNUf'></q></dir></style></legend>
              • 让我来为你详细讲解如何使用 Python 的 threading 和 Queue 模块来实现线程池。

                什么是线程池

                线程池是一种提高程序性能和减少资源消耗的技术,它可以实现多个线程共享一个线程池中的资源,减少创建和销毁线程所带来的损耗。线程池的基本实现原理是:在程序启动时创建指定数量的线程,将任务添加到队列中,线程从队列中取出任务并执行,当任务执行完毕后再将线程返回到池中等待下一次任务。

                Python 使用 threading+Queue 实现线程池

                首先,我们需要导入 threading 和 Queue 两个模块。其中,Queue 模块用来管理任务队列,threading 模块用来管理线程池。

                import threading
                import queue
                

                接下来,我们需要定义一个线程池类 ThreadPool,它主要包含以下几个方法:

                1. __init__(self, max_workers=10):初始化方法,用来创建指定数目的工作线程;
                2. submit(self, func, *args, **kwargs):将任务添加到任务队列中;
                3. worker(self):工作线程,用来从任务队列中取出任务并执行。
                class ThreadPool:
                    def __init__(self, max_workers=10):
                        self.max_workers = max_workers
                        self.tasks = queue.Queue()
                        self.workers = [threading.Thread(target=self.worker, daemon=True) for i in range(max_workers)]
                        for worker in self.workers:
                            worker.start()
                
                    def submit(self, func, *args, **kwargs):
                        self.tasks.put((func, args, kwargs))
                
                    def worker(self):
                        while True:
                            func, args, kwargs = self.tasks.get()
                            func(*args, **kwargs)
                            self.tasks.task_done()
                

                在上述代码中,我们首先定义了 __init__ 方法,它会创建指定数目的工作线程,并且将线程设为后台线程(即 daemon 线程),这样当主线程退出时,这些工作线程也会随着退出。

                接着,我们定义了一个 submit 方法,它将任务添加到任务队列中。

                最后,我们定义了一个 worker 方法,它会从任务队列中取出任务并执行。在执行完毕后,我们需要手动调用 task_done() 方法告诉任务队列这个任务已经完成。

                示例说明

                示例一:简单的任务执行

                我们来看一个简单的例子,假设我们需要计算一些数字的平方和,我们可以将这个任务加入到线程池中进行处理。

                def square_sum(num_list):
                    result = sum([num**2 for num in num_list])
                    print(f"The sum of squares is {result}")
                
                num_list = [1, 2, 3, 4, 5, 6, 7, 8, 9]
                pool = ThreadPool(max_workers=3)
                
                pool.submit(square_sum, num_list)
                

                在上面的代码中,我们定义了一个名为 square_sum 的函数,它接收一个包含数字的列表作为参数,然后计算这些数字的平方和,并打印出结果。

                接着,我们创建了一个最大线程数量为 3 的线程池,然后将 square_sum 函数和数字列表添加到线程池中进行处理。

                示例二:多个任务的同时处理

                我们再来看一个稍微复杂一些的例子,假设我们需要对一些文件进行加密操作,我们可以将这些文件的路径加入到任务队列中,然后使用线程池并发执行这些任务。

                def encrypt_file(file_path):
                    print(f"Encrypting file {file_path}")
                    # 在此处加入加密操作的代码
                
                file_list = ['/path/to/file1', '/path/to/file2', '/path/to/file3', '/path/to/file4', '/path/to/file5', '/path/to/file6']
                pool = ThreadPool(max_workers=3)
                
                for file_path in file_list:
                    pool.submit(encrypt_file, file_path)
                
                pool.tasks.join()
                

                在上面的代码中,我们定义了一个名为 encrypt_file 的函数,它接收一个文件路径作为参数,然后对这个文件进行加密。

                接着,我们创建了一个最大线程数量为 3 的线程池,然后将文件列表中的每个文件路径加入到任务队列中进行处理。

                最后,我们调用 tasks.join() 方法等待所有任务完成。

                总结

                线程池是一种提高程序性能和减少资源消耗的技术,Python 的 threading 和 Queue 模块可以轻松地实现线程池的功能。在实际开发中,我们可以将一些计算量较大、耗时较长的任务扔到线程池中并发执行,从而提高程序的运行效率。

                上一篇:用python实现的线程池实例代码 下一篇:Python多进程同步Lock、Semaphore、Event实例

                相关文章

                    <legend id='NFxpN'><style id='NFxpN'><dir id='NFxpN'><q id='NFxpN'></q></dir></style></legend>
                  1. <small id='NFxpN'></small><noframes id='NFxpN'>

                      <bdo id='NFxpN'></bdo><ul id='NFxpN'></ul>

                    <i id='NFxpN'><tr id='NFxpN'><dt id='NFxpN'><q id='NFxpN'><span id='NFxpN'><b id='NFxpN'><form id='NFxpN'><ins id='NFxpN'></ins><ul id='NFxpN'></ul><sub id='NFxpN'></sub></form><legend id='NFxpN'></legend><bdo id='NFxpN'><pre id='NFxpN'><center id='NFxpN'></center></pre></bdo></b><th id='NFxpN'></th></span></q></dt></tr></i><div id='NFxpN'><tfoot id='NFxpN'></tfoot><dl id='NFxpN'><fieldset id='NFxpN'></fieldset></dl></div>
                  2. <tfoot id='NFxpN'></tfoot>