首页 > hot资讯 > 探究多线程与多进程区别

探究多线程与多进程区别

更新时间:2020-11-25 17:51 浏览76次 来源:动力节点

进程的本质是程序在计算机上的一次执行活动,线程的本质是可执行代码的可分派单元,然而许多Java初学者很容易混淆两者的概念。事实上,多线程和多进程除了本质上的不同,在用法和作用方面也大不相同。本文我们就一起来探究多线程和多进程区别

 

说到多线程和多进程我们就不得不说到并发技术,可以让我们在同一时间同时执行多条任务。

对于「多任务」这个词,相信读者不会是第一次看见,现在的操作系统(如 Mac OS X、UNIX、Linux、Windows 等)都支持「多任务」操作系统。什么叫「多任务」呢?简单地说,就是系统可以同时运行多个任务。比如,一边用浏览器上网,一边听云音乐,一边聊天,这就是多任务。此时手头已经有 3 个任务在运行了。如果查看任务管理器,可以看到还有很多任务悄悄在后台运行着,只是桌面上没有显示而已。对于操作系统来说,一个任务就是一个进程,开启多个任务就是多进程。有些进程不止可以同时做一件事,比如 Word 可以同时打字、检查拼写、打印等。在一个进程内部,要同时做多件事,就需要同时运行多个线程。


我们先来看看多线程和多进程的定义:

进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位,是“活的”

 

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

 

一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行(轮流获取cpu的时间片,在总体上给人的感觉是同时在执行,这是并发,还有一个名词叫并行,就是多核多cpu,真正的同时在执行,不过现在实现难度有点大,在用处上主要用在并行计算),至少要有一个线程。相对进程而言,线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。

 

进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

 

1、简而言之,一个程序至少有一个进程,一个进程至少有一个线程.

 

2、 线程的划分尺度小于进程,使得多线程程序的并发性高。

 

3、 另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。

 

4、 线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

 

5、 从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。

 

实际上多线程和多进程在使用上各有优缺点:多线程执行开销小,但不利于资源的管理和保护;而多进程正相反。这也是多线程和多进程之间最明显的区别,除此之外,多线程间通信和多进程间通信也大不相同,关于这一点,在本站的多线程教程中有详细的讲解。



热门课程推荐

全部班型支持免费试学

动力节点在线报名表(此信息已加密,请放心填写)

返回顶部