任务、进程和线程的区别(转自博客园)_繁杂琐事
来源:互联网 发布:女性职场歧视 知乎 编辑:程序博客网 时间:2024/05/16 00:46
进程(process)常常被定义为程序的执行。可以把一个进程看成是一个独立的程序,在内存中有其完备的数据空间和代码空间。一个进程所拥有的数据和变量只属于它自己。
线程(thread)则是某一进程中一路单独运行的程序。也就是说,线程存在于进程之中。一个进程由一个或多个线程构成,各线程共享相同的代码和全局数据,但各有其自己的堆栈。由于堆栈是每个线程一个,所以局部变量对每一线程来说是私有的。由于所有线程共享同样的代码和全局数据,它们比进程更紧密,比单独的进程间更趋向于相互作用,线程间的相互作用更容易些,因为它们本身就有某些供通信用的共享内存:进程的全局数据。
一个进程和一个线程最显著的区别是:线程有自己的全局数据。线程存在于进程中,因此一个进程的全局变量由所有的线程共享。由于线程共享同样的系统区域,操作系统分配给一个进程的资源对该进程的所有线程都是可用的,正如全局数据可供所有线程使用一样。
简而言之,一个程序至少有一个进程,一个进程至少有一个线程。线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。从逻辑角度来看,多线程的意义在于一个应用程序中,由多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配,这就是进程和线程的重要区别。
一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行。
进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一 个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程 序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。
进程概念
进程是表示资源分配的基本单位,又是调度运行的基本单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘 空间、I/O设备等。然后,把该进程放人进程的就绪队列。进程调度程序选中它,为它分配CPU以及其它有关资源,该进程才真正运行。所以,进程是系统中的 并发执行的单位。
在Mac、Windows NT等采用微内核结构的操作系统中,进程的功能发生了变化:它只是资源分配的单位,而不再是调度运行的单位。在微内核系统中,真正调度运行的基本单位是线程。因此,实现并发功能的单位是线程。
线程概念
引入线程的好处
(1)易于调度。
(2)提高并发性。通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。
(3)开销少。创建线程比创建进程要快,所需开销很少。
(4)利于充分发挥多处理器的功能。通过创建多线程进程(即一个进程可具有两个或更多个线程),每个线程在一个处理器上运行,从而实现应用程序的并发性,使每个处理器都得到充分运行。
进程和线程的关系
(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
(2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。
(3)处理机分给线程,即真正在处理机上运行的是线程。
(4)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。
- 任务、进程和线程的区别(转自博客园)_繁杂琐事
- 线程和进程的区别;进程、线程、任务的区别?
- 进程和线程(转载自廖雪峰的博客)
- 任务、进程和线程的区别
- 进程、线程、服务和任务的区别
- 进程、线程、服务和任务的区别
- 20170906_线程和进程的区别
- 20170925_线程和进程的区别
- android 中 任务、进程和线程的区别
- [android基础知识] 之二: 任务、进程和线程的区别
- android 中 任务、进程和线程的区别
- android 中 任务、进程和线程的区别
- android 中 任务、进程和线程的区别
- 程序、任务、进程和线程的联系与区别
- android 中 任务、进程和线程的区别
- 程序、任务、进程和线程的联系与区别
- android 中 任务、进程和线程的区别
- 作业、任务、进程、线程的区别
- 【张孝祥并发课程笔记】06:多线程共享数据的方式探讨
- kvm虚拟主机安装速度很慢
- 影响未来十年的10项互联网新技术
- 【张孝祥并发课程笔记】07:java5原子性操作类的应用
- 鼠标相关
- 任务、进程和线程的区别(转自博客园)_繁杂琐事
- 【张孝祥并发课程笔记】08:java5线程并发库的应用
- LEETCODE: Intersection of Two Linked Lists
- boost::timer
- 史上最详细的Android Studio系列教程三--快捷键
- hdu 2795 线段树
- 【张孝祥并发课程笔记】09:Callable与Future的应用
- 20150302 N1
- struts2连接数据库实现用户登录