zoukankan      html  css  js  c++  java
  • 进程与线程

    一、进程与线程
        进程是系统进行资源分配和调度的一个独立单位。用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等,然后就该进程被放入到进程的就绪队列,进程调度程序选择它,为它分配CPU及其他相关资源,该进程就被运行起来。
     
        线程是进程的一个实体,是CPU调度和分配的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器、一组寄存器和栈),但是它可以与同属一个进程的其他的线程共享进程所拥有的全部资源。
     
        在没有实现线程的操作系统中,进程既是资源分配的基本单位,又是调度的基本单位,它是系统中并发执行的单元。而在实现了线程的操作系统中,进程是资源分配的基本单位,但线程是调度的基本单位,是系统中并发执行的单元。
     
    1、引入线程的优点
    a)易于调度
    b)提高并发性
    c)开销小。创建线程比创建进程要快,所需要的开销也更少
    d)有利于处理器发挥多处理器的功能。通过创建多线程,每个线程都 在一个处理器上运行,从而实现应用程序的并行,使每个处理器得到充分的运行
     
    2.线程与进程的区别
    a)一个线程必定属于也只能属于一个进程;而一个进程可以拥有多个线程并且至少拥有一个线程
    b)属于一个进程的所有线程共享该线程的所有资源,包括打开的文件,创建的socket等。不同的进程相互独立
    c)线程又称为轻量级进程。进程由进程控制块,线程也有线程控制块。但线程控制块比进程控制块小得多。线程间切换代价小,进程间切换代价大。
    d)进程是程序的一次执行,线程可以理解为程序中一段程序片段的执行
    e)每个进程都有独立的内存空间,而线程共享其所属进程的内存空间
     
     
    二、线程同步的机制
    1.临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。
     
    2.互斥量:只有拥有互斥对象的线程才有权去访问系统的公共资源,因为互斥对象只有一个,所以能够保证资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享。
     
    3.信号量:为控制一个具有有限数量的用户资源而设计。它允许多个线程在同一时刻去访问同一个资源。
     
    4.事件:用来通知线程有一些事件发生,从而启动后继任务的开始
     
    三、内核线程和用户线程的区别
        根据操作系统是否对线程可感知,可以把线程分为内核线程和用户线程。
     
        内核线程建立和销毁都是由OS负责、通过系统调用完成的,操作系统在调度时,参考各进程内的线程运行情况作出调度决定。如果一个进程中没有就绪态的线程,那么这个进程也不会被调用占用CPU。
     
        和内核线程对应的是用户线程,用户线程指不需要内核支持而在用户程序中实现线程,其不依赖于操作系统的核心,用户进程利用线程库提供创建、同步、调度和管理线程的函数来控制用户线程。用户线程多见于一些历史悠久的OS,如UNIX,不需要用户态/内核态切换,速度快,操作系统内核不知道多线程的存在,因此一个线程阻塞将使得整个进程阻塞。由于这里的处理器时间片分配是以进程为单位的,所以每个线程执行的时间相对减少。
     
    1.引入用户线程的优势
    a)可以在不支持线程的操作系统中实现
    b)创建和销毁线程、线程切换等线程管理的代价比内核线程少的多
    c)允许每个进程定制自己的调度算法,线程管理比较灵活
    d)线程能够利用的表空间和堆栈空间比内核线程多
     
    2、用户线程的缺点
    a)同一进程中只能同时有一个线程在运行,如果有一个线程使用了系统调用而阻塞,那么整个进程都会被挂起
    b)页面失效也会产生类似的问题
  • 相关阅读:
    元组
    字典
    列表
    数据类型-字符串(str)
    python安装和首次使用
    javac++的stl解决重复的元素
    c++二分法求一个数的完全平方数
    双指针法----->求数组中两数之和
    java的二分法求一个数的平方根
    Java递归加上二分搜索将有序数组转化为平衡二叉树2
  • 原文地址:https://www.cnblogs.com/yuyang0920/p/7278015.html
Copyright © 2011-2022 走看看