进程与线程
一、进程与线程概述
程序
- 程序(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
本文介绍了进程与线程的概念,强调了线程作为CPU调度执行的基本单元的角色。通过对比单线程和多线程的执行效率,展示了多线程的优势。接着,讲解了如何在PyCharm中创建进程和线程,以及通过继承threading.Thread类实现多线程的方法。讨论了线程的常用方法,并提出了多线程访问全局变量的安全性问题,通过车站售票案例说明问题。最后,引入了锁机制来解决安全性问题,详细阐述了加锁和释放锁的步骤。
最低0.47元/天 解锁文章
248

被折叠的 条评论
为什么被折叠?



