是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竞争计算机系统资源的基本单位
是进程的一个执行单元,是进程内科调度实体。比进程更小的独立运行的基本单位。线程也被称为轻量级进程
是一种比线程更加轻量级的存在。一个线程也可以拥有多个协程。其执行过程更类似于子例程,或者说不带返回值的函数调用
进程和线程的根本区别是操作系统(OS)资源分配的基本单位,而线程是处理器(cpu)任务调度和执行的基本单位
线程共享本进程的地址空间,而进程之间是独立的地址空间
线程共享本进程的资源如:内存、I/O口、cpu等,不利于资源的管理和保护,而进程之间的资源是独立的,能很好的进行资源的管理和保护
多进程要比多线程健壮,一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉
每个独立的进程有一个程序运行的入口、顺序执行序列和程序入口,执行开销大
但是线程不能独立执行,必须依存在应用程序中由应用程序提供多个线程执行控制,执行开销小
两者均可并发执行
进程切换时,消耗的资源大,效率高。所以涉及到频繁的切换时,使用线程要好于进程。同样如果要求同时进行并且又要共享某些变量的并发操作,只能用线程不能用进程
线程是处理器调度的基本单位,但进程不是
线程
相对独立、有自己的上下文、切换受系统控制
协程
相对独立、有自己的上下文、切换由自己控制,由当前协程切换到其他协程由当前协程来控制
何时使用多进程,何时使用多线程
对资源的管理和保护要求高,不限制开销和效率时,使用多进程
要求效率高,切换频繁时,资源的保护管理要求不是很高时,使用多线程
为什么会有线程?
要求高,不限制开销和效率时,使用多进程
要求效率高,切换频繁时,资源的保护管理要求不是很高时,使用多线程
为什么会有线程?
每个进程都有自己的地址空间,即进程空间,在网络或多用户换机下,一个服务器通常需要接收大量不确定数量用户的并发请求,为每个请求都创建一个进程显然行不通(系统开销大响应用户请求效率低),因此操作系统中线程概念被引进