进程vs线程

什么叫“多任务”呢?

简单地说,就是操作系统可以同时运行多个任务。

打个比方,你一边在用浏览器上网,一边在听MP3,一边在用Word赶作业,这就是多任务,至少同时有3个任务正在运行。还有很多任务悄悄地在后台同时运行着,只是桌面上没有显示而已。

现在,多核CPU已经非常普及了,但是,即使过去的单核CPU,也可以执行多任务。由于CPU执行代码都是顺序执行的,那么,单核CPU是怎么执行多任务的呢?

答案就是操作系统轮流让各个任务交替执行,任务1执行0.01秒,切换到任务2,任务2执行0.01秒,再切换到任务3,执行0.01秒……这样反复执行下去。表面上看,每个任务都是交替执行的,但是,由于CPU的执行速度实在是太快了,我们感觉就像所有任务都在同时执行一样。

真正的并行执行多任务只能在多核CPU上实现,但是,由于任务数量远远多于CPU的核心数量,所以,操作系统也会自动把很多任务轮流调度到每个核心上执行。

功能

进程,能够完成多任务,比如 在一台电脑上能够同时运行多个QQ
线程,能够完成多任务,比如 一个QQ中的多个聊天窗口

定义的不同

进程是系统进行资源分配和调度的一个独立单位.
线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.

区别

一个程序至少有一个进程,一个进程至少有一个线程.
线程的划分尺度小于进程(资源比进程少),使得多线程程序的并发性高。
进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率
线线程不能够独立执行,必须依存在进程中

优缺点

线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程正相反。 

进程池

当需要创建的子进程数量不多时,可以直接利用multiprocessing中的Process动态生成多个进程,但是如果是上百个个目标,手动的去创建进程工作量巨大,此时就可以使用multiprocessing模块提供的Pool方法.

初始化Pool时,可以指定一个最大进程数,当有新的请求提交到Pool中时,如果池还没有满,那么就会创建一个新的进程用来执行该请求;但如果池中的进程数已经达到指定的最大值,那么该请求就会等待,直到池中有进程结束,才会创建新的进程来执行。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
进程线程都是计算机中的并发执行模型,它们的最大区别在于进程是操作系统资源分配的基本单位,而线程是程序执行的基本单位。下面是它们的优缺点和使用场景: 进程的优点: 1. 进程之间互相隔离,相互之间不会影响; 2. 进程之间共享数据简单,可以使用IPC机制进行通信; 3. 进程可以利用多核CPU进行并发执行; 4. 进程崩溃不会影响其它进程进程的缺点: 1. 进程创建、切换和销毁的开销比较大; 2. 进程之间的通信比较耗时; 3. 操作系统需要为每个进程分配独立的内存空间,占用较多的内存资源。 线程的优点: 1. 线程创建、切换和销毁的开销比进程小很多; 2. 线程之间的通信比进程之间的通信更加快速和简便; 3. 多线程可以充分利用CPU的多核特性,提高程序的并发执行能力; 4. 线程之间共享内存,数据共享简单。 线程的缺点: 1. 线程之间没有隔离,一个线程崩溃可能会影响整个程序; 2. 线程之间的共享数据容易引起数据竞争; 3. 线程的数量过多会影响程序的性能。 使用场景: 一般来说,进程适用于需要隔离的场景,比如操作系统的进程管理、Web服务器的多进程模型等;线程适用于需要并发、数据共享的场景,比如图形界面程序、网络服务器的多线程模型等。在实际应用中,根据具体的需求和应用场景来选择合适的并发执行模型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值