Python学习 Day53 爬虫进阶——进程线程 01

进程与线程

一、进程与线程概述

程序

  • 程序(Program)是计算机指令的集合,用于实现特定功能

进程

  • 1.启动后的程序称为进程,系统会为进程分配内存空间
  • 2.一个进程中至少包含一个线程
    在这里插入图片描述

线程

  • 1.CPU调度执行的基本单元
  • 2.一个进程中包含多个线程
  • 3.进程结束,线程一定结束,线程结束,进程不一定结束
  • 4.同一个进程中的多个线程,共享内存地址

二、进程与线程的区别

区别 进程 线程
根本区别 资源分配的单位 调度和执行的单位
开销 每个进程都有独立的代码和数据控价(寄存器、堆栈、上下文) 线程是轻量级的进程,同一进程的线程共享代码和数据空间,线程间的切换空间小
所处环境 在操作系统中同时运行多个任务(程序) 同一应用程序有多个顺序流同时执行
分配内存 系统在运行的时候会为每一个进程分配不同的内存空间 除了CPU之外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),同一进程的线程共享资源
包含关系 进程中包含多个线程,只有一个线程的进程称为单线程 线程是进程的一部分

三、pycharm建立进程与线程

单线程:fun1()和fun2()执行完都需要5s的时间,所以整个程序完成的时间为10s

import time
def fun1():
    for i in range(5):
        print('------fun1中i的值为:',i)
        #休眠一秒后再执行其他语句
        time.sleep(1)

def fun2():
    for i in range(5):
        print('===============fun2中i的值为:',i)
        # 休眠一秒后再执行其他语句
        time.sleep(1)

def single():
    fun1()
    fun2()

if __name__ == '__main__':
    single()
------fun1中i的值为: 0
------fun1中i的值为: 1
------fun1中i的值为: 2
------fun1中i的值为: 3
------fun1中i的值为: 4
===============fun2中i的值为: 0
===============fun2中i的值为: 1
===============fun2中i的值为: 2
===============fun2中i的值为: 3
===============fun2中i的值为: 4

Process finished with exit code 0

多线程:fun1和fun2并行执行,程序运行时间为5s

import time
import threading
def fun1():
    for i in range(5):
        print('------fun1中i的值为:',i)
        #休眠一秒后再执行其他语句
        time.sleep(1)

def fun2():
    for i in range(5):
        print('===============fun2中i的值为:',i)
        # 休眠一秒后再执行其他语句
        time.sleep(1)

def single():
    fun1()
    fun2()

def mult():
    #创建线程对象
    t1 = threading.Thread
  • 10
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值