线程与进程的区别

 

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