python多进程和多线程

前言

进程是资源分配的最小单位,线程是CPU调度的最小单位

进程:操作系统的每个一个程序都是一个进程
线程:进程包括了线程,一个进程下可以有多个线程同时进行

一、多进程

代码如下(示例):

# -*- coding: utf-8 -*-
"""
@Time : 2022/5/20 13:20
@Author : 盘盘
@File :more_process.py
@IDE :PyCharm

"""
from random import randint
from time import time
from multiprocessing import Process

def open(url):
    print("打开博客:%s" % url)
    time = randint(1,10)
    print("打开博客:%s,耗时:%d秒" % (url, time))

def process_run():
    start = time()
    pro1 = Process(target=open,args=("https://blog.csdn.net/weixin_44688529?spm=1010.2135.3001.5343",))
    p1.start()
    p2 = Process(target=open, args=("https://www.baidu.com/",))
    p2.start()
    p1.join()
    p2.join()
    end = time()
    print('总共耗费了%.2f秒.' % (end - start))

if __name__ == '__main__':
    process_run()

二、多线程

代码如下(示例):

# -*- coding: utf-8 -*-
"""
@Time : 2022/5/20 13:28
@Author : 盘盘
@File :more_thread.py
@IDE :PyCharm

"""
from random import randint
from threading import Thread
from time import time

def open(url):
    print("打开博客:%s" % url)
    time = randint(1,10)
    print("打开博客:%s,耗时:%d秒" % (url, time))

def thread_run():
    start = time()
    t1 = Thread(target=open,args=("https://blog.csdn.net/weixin_44688529?spm=1010.2135.3001.5343",))
    t1.start()
    t2 = Thread(target=open, args=("https://www.baidu.com/",))
    t2.start()
    t1.join()
    t2.join()
    end = time()
    print('总共耗费了%.2f秒.' % (end - start))

if __name__ == '__main__':
    thread_run()

总结

线程执行开销小,但不利于资源的管理和保护,而进程正相反。而且同一进程多个线程之间是数据共享的,多个进程之间数据相互独立,但是可以采取一些方式进行信息交互(比如队列)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值