`
8366
  • 浏览: 809246 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

任务、进程和线程的区别(转)

阅读更多

任务(task)是最抽象的,是一个一般性的术语,指由软件完成的一个活动。一个任务既可以是一个进程,也可以是一个线程。简而言之,它指的是一系列共同达到某一目的的操作。例如,读取数据并将数据放入内存中。这个任务可以作为一个进程来实现,也可以作为一个线程(或作为一个中断任务)来实现。

  进程(process)常常被定义为程序的执行。可以把一个进程看成是一个独立的程序,在内存中有其完备的数据空间和代码空间。一个进程所拥有的数据和变量只属于它自己。

  线程(tread)则是某一进程中一路单独运行的程序。也就是说,线程存在于进程之中。一个进程由一个或多个线程构成,各线程共享相同的代码和全局数据,但各有其自己的堆栈。由于堆栈是每个线程一个,所以局部变量对每一线程来说是私有的。由于所有线程共享同样的代码和全局数据,它们比进程更紧密,比单独的进程间更趋向于相互作用,线程间的相互作用更容易些,因为它们本身就有某些供通信用的共享内存:进程的全局数据。

  一个进程和一个线程最显著的区别是:线程有自己的全局数据。线程存在于进程中,因此一个进程的全局变量由所有的线程共享。由于线程共享同样的系统区域,操作系统分配给一个进程的资源对该进程的所有线程都是可用的,正如全局数据可供所有线程使用一样

 

进程概念 
  进程是表示资源分配的基本单位,又是调度运行的基本单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等。然后,把该进程放人进程的就绪队列。进程调度程序选中它,为它分配CPU以及其它有关资源,该进程才真正运行。所以,进程是系统中的并发执行的单位。 
  在Mac、Windows NT等采用微内核结构的操作系统中,进程的功能发生了变化:它只是资源分配的单位,而不再是调度运行的单位。在微内核系统中,真正调度运行的基本单位是线程。因此,实现并发功能的单位是线程。
线程概念 
  线程是进程中执行运算的最小单位,亦即执行处理机调度的基本单位。如果把进程理解为在逻辑上操作系统所完成的任务,那么线程表示完成该任务的许多可能的子任务之一。例如,假设用户启动了一个窗口中的数据库应用程序,操作系统就将对数据库的调用表示为一个进程。假设用户要从数据库中产生一份工资单报表,并传到一个文件中,这是一个子任务;在产生工资单报表的过程中,用户又可以输人数据库查询请求,这又是一个子任务。这样,操作系统则把每一个请求――工资单报表和新输人的数据查询表示为数据库进程中的独立的线程。线程可以在处理器上独立调度执行,这样,在多处理器环境下就允许几个线程各自在单独处理器上进行。操作系统提供线程就是为了方便而有效地实现这种并发性
引入线程的好处
(1)易于调度。
(2)提高并发性。通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。
(3)开销少。创建线程比创建进程要快,所需开销很少。。
(4)利于充分发挥多处理器的功能。通过创建多线程进程(即一个进程可具有两个或更多个线程),每个线程在一个处理器上运行,从而实现应用程序的并发性,使每个处理器都得到充分运行。
进程和线程的关系
(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
(2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。
(3)处理机分给线程,即真正在处理机上运行的是线程。
(4)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。

分享到:
评论

相关推荐

    进程和线程之间的关系

    在计算机科学领域中,进程和线程是两个非常重要的概念,它们之间既有联系又有区别。对于初学者来说,理解进程与线程的关系至关重要,因为这有助于深入掌握操作系统的基本原理及应用。下面将详细阐述进程与线程之间的...

    进程与线程的生动形象理解

    进程与线程作为操作系统中的核心概念,对于理解和开发高效的软件至关重要。本文旨在通过一个生动的类比来帮助读者更好地理解进程与线程的基本概念及其差异,并进一步探讨它们在实际应用中的联系与区别。 #### 二、...

    进程和线程详解

    进程和线程之间的区别主要体现在以下几个方面: 1. 资源分配:进程拥有独立的资源,如内存、文件描述符等;而线程共享进程的资源。 2. 创建销毁成本:创建和销毁进程的开销较大,因为涉及资源分配;线程的创建和销毁...

    c语言多进程多线程编程

    在计算机科学中,多进程和多线程是两种并发执行的方式,它们允许程序在同一时间处理多个任务,从而提高系统的效率和响应性。C语言作为一门底层且强大的编程语言,提供了丰富的系统调用接口来实现多进程和多线程编程...

    进程和线程的区别与联系

    进程和线程是计算机操作系统中的两个基本概念,它们在程序执行和系统资源管理中起着至关重要的作用。本文将深入探讨这两个概念的区别、联系以及在Java环境中的具体应用。 首先,程序是静态的代码集合,它是一组指令...

    JAVA线程与进程的区别

    这就是进程和线程的重要区别。 在 Unix 操作系统中,进程是 Unix 操作系统环境中的基本成分、是系统资源分配的基本单位。进程在执行过程中有内存单元的初始入口点,并且进程存活过程中始终拥有独立的内存地址空间;...

    最清楚的进程线程,进程和线程对比

    在操作系统中,进程和线程是两个非常核心的概念,它们代表了程序在系统中的运行状态以及运行方式。为了深入理解这两个概念,我们首先要明确什么是进程。 进程是具有一定独立功能的程序关于某个数据集合上的一次运行...

    c++进程与线程

    在计算机科学领域,C++是一种强大的编程语言,它支持创建多进程和多线程的应用程序。进程和线程是操作系统中的基本概念,对于理解和优化软件性能至关重要。让我们深入探讨这两个概念以及它们在C++编程中的应用。 **...

    进程与线程的一个简单解释

    了解和掌握进程与线程的区别和交互机制,对于编写高效的多线程程序至关重要。通过互斥锁和信号量等同步工具,我们可以有效地控制线程的并发访问,确保程序的正确性和性能。在实际开发中,合理地使用进程和线程,结合...

    内核线程和进程的区别

    内核线程和进程的区别主要体现在它们在Linux操作系统中的实现机制和运行方式。首先需要理解的是,在Linux系统中,线程被抽象为一种特殊的进程,称为轻量级进程(Lightweight Process, LWP)。这种机制与传统的线程...

    进程与线程的管理 .PPT 进程、线程和优先级

    而线程则是执行的基本单元,是进程中独立的执行路径,每个进程至少有一个主线程,用于启动和执行进程的主要任务。 线程的优先级是调度的重要依据,Windows系统中,线程被分为32个优先级等级,从0到31,0表示最低...

    delphi进程和线程

    进程和线程是操作系统中两种重要的执行单元。进程是系统分配资源的基本单位,每个进程都有自己独立的内存空间,这使得进程之间的数据无法直接共享,但可以借助于通信机制进行交互。当一个进程崩溃时,由于其拥有独立...

    线程和进程的区别.txt

    ### 线程和进程的区别 #### 进程与线程的基本概念 在现代操作系统(如Windows、UNIX等)中,进程(Process)和线程(Thread)是两个非常重要的概念,它们对于理解和设计多任务操作系统及其应用程序至关重要。进程...

    C#进程和线程资料集锦

    "C#进程和线程资料集锦"这一主题涵盖了进程与线程的基本概念、管理和同步技术,是C#开发者必备的知识库。 **进程与线程** 1. **进程**:进程是操作系统资源分配的基本单位,每个运行的应用程序都有一个独立的进程。...

    Windows进程和线程

    Windows 进程和线程 Windows 操作系统是一个多任务操作系统,可以同时执行多个进程。每个进程都有自己的地址空间,进程之间无法访问对方的地址空间。进程的特点包括: 1. 每个进程都有自己的 ID 号 2. 每个进程都...

    线程,进程,程序的区别

    进程和线程的区别主要表现在以下几个方面: 1. 地址空间和其他资源:进程间是相互独立的,每个进程拥有自己的地址空间和资源,如打开的文件等。而线程则共享所属进程的资源,如内存和I/O设备等。 2. 通信:进程...

    死锁,进程和线程实验报告

    Linux是一种自由开放源码的类Unix系统,它的多任务和多用户特性使得进程和线程的管理变得尤为重要。我们利用`strace`工具跟踪系统调用,了解进程和线程的生命周期;通过`/proc`文件系统获取进程信息,观察它们的资源...

    操作系统(进程和线程创建及其线程模型).docx

    Linux进程和线程创建:进程、用户级线程和内核级线程的区别与联系 在Linux环境中,进程和线程的创建和管理非常重要。下面分别介绍进程、用户级线程和内核级线程的区别与联系。 - **进程**:是操作系统资源分配的...

Global site tag (gtag.js) - Google Analytics