【补充】进程理论
【一】开设多进程的两种方式
【1】在Windows上启动子进程
'''
由于Windows没有fork,多处理模块启动一个新的Python进程并导入调用模块。
如果在导入时调用Process(),那么这将启动无限继承的新进程(或直到机器耗尽资源)。
这是隐藏对Process()内部调用的原,使用if **name** == “**main** ”,
这个if语句中的语句将不会在导入时被调用。
'''
【2】multiprocessing使用
import multiprocessing
import random
import time
def work(name):
print(f"{name} is starting \n")
sleep_time = random.randint(1, 6)
print(f"{name} is sleeping {sleep_time} s \n")
time.sleep(sleep_time)
print(f"{name} is ending \n")
def main_object():
task_1 = multiprocessing.Process(
target=work,
args=("work_1",)
)
task_2 = multiprocessing.Process(
target=work,
kwargs={'name': 'work_2'}
)
task_1.start()
task_2.start()
class MyProcess(multiprocessing.Process):
def __init__(self, name):
super().__init__()
self.name = name
def run(self):
print(f"{self.name} is starting \n")
sleep_time = random.randint(1, 6)
print(f"{self.name} is sleeping {sleep_time} s \n")
time.sleep(sleep_time)
print(f"{self.name} is ending \n")
def main_class():
task_1 = MyProcess(name='work_1')
task_2 = MyProcess(name='work_2')
task_1.start()
task_2.start()
if __name__ == '__main__':
start_time = time.time()
print(f"这是主进程 __main__ 开始 :>>>> \n")
main_class()
print(f"这是主进程 __main__ 结束 :>>>> \n")
end_time = time.time()
print(f'总耗时 :>>>> {end_time - start_time}s')
【二】子进程之间的数据是隔离的
import multiprocessing
money = 9999
def change_money(name):
global money
print(f'{name} 原始的money :>>>> {money}')
money = 8888
print(f'{name} 当前子进程修改后的money :>>>> {money}')
def main():
for i in range(10):
task = multiprocessing.Process(
target=change_money,
args=(i,)
)
task.start()
if __name__ == '__main__':
main()
【三】多进程实现服务端并发
import socket
client = socket.socket()
ip = '127.0.0.1'
port = 8802
addr = (ip, port)
client.connect(addr)
while True:
letter = input("请输入字母:>>>> ").strip()
client.send(letter.encode())
if letter == 'q':
client.close()
break
data = client.recv(1024)
print(f"这是来自服务单的数据 :>>>> {data.decode()}")
【1】未实现并发
import socket
server = socket.socket()
ip = '127.0.0.1'
port = 8802
addr = (ip, port)
server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
server.bind(addr)
server.listen(1)
conn, addr = server.accept()
while True:
data = conn.recv(1024)
if data.decode() == 'q':
conn.close()
print(f'这是来自客户端的数据 :>>>>{data.decode()}')
conn.send(data.decode().upper().encode())
【2】实现并发
import multiprocessing
import socket
server = socket.socket()
ip = '127.0.0.1'
port = 8802
addr = (ip, port)
server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
server.bind(addr)
server.listen(0)
def run(conn):
while True:
data = conn.recv(1024)
if data.decode() == 'q':
conn.close()
print(f'这是来自客户端的数据 :>>>>{data.decode()}')
conn.send(data.decode().upper().encode())
def main():
while True:
conn, addr = server.accept()
task = multiprocessing.Process(target=run, args=(conn,))
task.start()
if __name__ == '__main__':
main()
【四】join实现并发
【1】主进程结束子进程未结束
import multiprocessing
import random
import time
def work(name):
print(f"{name} is starting \n")
sleep_time = random.randint(1, 6)
print(f"{name} is sleeping {sleep_time} s \n")
time.sleep(sleep_time)
print(f"{name} is ending \n")
def main_object():
task_list = [multiprocessing.Process(
target=work,
args=(f"work_{i}",)
) for i in range(5)]
task_list = [task.start() for task in task_list]
if __name__ == '__main__':
start_time = time.time()
print(f"这是主进程 __main__ 开始 :>>>> \n")
main_object()
print(f"这是主进程 __main__ 结束 :>>>> \n")
end_time = time.time()
print(f'总耗时 :>>>> {end_time - start_time}s')
【2】主进程等待子进程结束(join串行)
import multiprocessing
import random
import time
def work(name):
print(f"{name} is starting \n")
sleep_time = random.randint(1, 6)
print(f"{name} is sleeping {sleep_time} s \n")
time.sleep(sleep_time)
print(f"{name} is ending \n")
def main_object():
task_list = [multiprocessing.Process(
target=work,
args=(f"work_{i}",)
) for i in range(5)]
for task in task_list:
task.start()
task.join()
if __name__ == '__main__':
start_time = time.time()
print(f"这是主进程 __main__ 开始 :>>>> \n")
main_object()
print(f"这是主进程 __main__ 结束 :>>>> \n")
end_time = time.time()
print(f'总耗时 :>>>> {end_time - start_time}s')
【3】主进程等待子进程结束(join并行)
import multiprocessing
import random
import time
def work(name):
print(f"{name} is starting \n")
sleep_time = random.randint(1, 6)
print(f"{name} is sleeping {sleep_time} s \n")
time.sleep(sleep_time)
print(f"{name} is ending \n")
def main_object():
task_list = []
for i in range(5):
task = multiprocessing.Process(
target=work,
args=(f"work_{i}",)
)
task.start()
task_list.append(task)
for task in task_list:
task.join()
if __name__ == '__main__':
start_time = time.time()
print(f"这是主进程 __main__ 开始 :>>>> \n")
main_object()
print(f"这是主进程 __main__ 结束 :>>>> \n")
end_time = time.time()
print(f'总耗时 :>>>> {end_time - start_time}s')
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南