python 子线程阻塞主线程,Python多处理/线程阻塞主线程

我正在尝试用Python编写一个程序。我想写的是一个脚本,它会立即向用户返回友好的消息,但会在后台生成一个很长的子进程,该子进程处理多个不同的文件并将它们写入一个原始文件。我已经做了一些关于线程和处理的教程,但是我遇到的是,无论我尝试什么,程序都会一直等待直到子进程完成,然后才会向用户显示前面提到的友好消息。以下是我尝试过的:

线程示例:#!/usr/local/bin/python

import cgi, cgitb

import time

import threading

class TestThread(threading.Thread):

def __init__(self):

super(TestThread, self).__init__()

def run(self):

time.sleep(5)

fileHand = open('../Documents/writable/output.txt', 'w')

fileHand.write('Big String Goes Here.')

fileHand.close()

print 'Starting Program'

thread1 = TestThread()

#thread1.daemon = True

thread1.start()

最后一种说法是在Python中并发运行线程实际上是不可能的。很公平。这些文章中的大多数都提到了多处理模块,所以我已经读过了,而且看起来相当简单。以下是我找到的一些资源:

下面是一个翻译成多处理的例子:

^{pr2}$

我想要的是让这些程序立即打印“启动程序”(在web浏览器中),然后几秒钟后,一个文本文件出现在我授予写入权限的目录中。然而,实际发生的情况是,它们都有5秒钟没有响应,然后它们打印“启动程序”并同时创建文本文件。我知道我的目标是可能的,因为我已经用PHP实现了,使用了以下技巧://PHP

exec("php child_script.php > /dev/null &");

我想在Python中是可能的。请让我知道,如果我错过了一些明显的东西,或者我想这是完全错误的方式。谢谢你的时间!在

(系统信息:Python2.7.6,MacOSX小牛。Python与自制程序一起安装。我的Python脚本在apache2.2.26中作为CGI可执行文件运行)

Python 使用的是基于线程的并发模型,但是默认的全局解释器锁(Global Interpreter Lock, GIL)限制了在同一时刻只有一个线程在执行Python字节码。这就意味着在Python的单进程中,多线程只能用于I/O密集型任务,因为这时线程间的切换并不涉及到CPU计算资源的竞争。 因此,在Python中,线程本身并不直接阻塞线程。然而,如果线程执行了I/O操作或其他阻塞式的操作(如文件读写、网络请求等),则整个进程阻塞,因为GIL不允许其他线程进入执行状态。此时,线程实际上也被阻塞了,直到线程完成其操作并返回执行结果。 举个例: ```python import threading import time def long_running_task(): print("Starting a blocking I/O task...") # 模拟I/O操作,这里只是简单地让线程睡眠几秒 time.sleep(5) print("I/O task finished.") # 创建一个线程实例,并通过目标函数和参数初始化 t = threading.Thread(target=long_running_task) # 开始线程 t.start() print("Main thread is still running.") ``` 在这个例中,尽管`main_thread`继续执行并打印了消息,但由于`long_running_task`中包含了一个模拟的长时间I/O操作,所以整个程序实际上被阻塞到了`time.sleep(5)`这一行,直到I/O操作完成。 解决阻塞问题的一种常见做法是将I/O密集型任务放在单独的进程中运行,而不是在同一个线程中。这样,即便这个进程内的某个线程阻塞,也不影响到其他线程进程内的其他操作。对于CPU密集型任务来说,多线程可以在Python中有效地利用多核处理器,因此在这种情况下,GIL通常不成为性能瓶颈。 --- --- 相关问题 --- 1. 如何在Python中安全地处理GIL以提高多线程程序的性能? 2. 是否有纯Python实现的替代方案,可以在多核处理器上充分利用硬件资源? 3. 在哪些场景下,多线程Python中的使用效率比单一进程更高?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值