操作系统:进程管理(概念)

原创 2016年05月30日 10:40:24

对于计算机系统而言,操作系统充当着基石的作用,它是连接计算机底层硬件与上层应用软件的桥梁,控制其他程序的运行,并且管理系统相关资源,同时提供配套的系统软件支持。对于专业的程序员而言,掌握一定的操作系统知识比不可少,因为不管面对的是底层嵌入式开发,还是上层的云计算开发,都需要使用到一定的操作系统相关知识。

进程与线程有什么区别

进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,它是系统进行资源分配和调度的一个独立单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等,然后该进程被放入到进程的就绪队列,进程调度程序选中它,为它分配CPU及其他相关资源,该进程就被运行起来。

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

在没有实现线程的操作系统中,进程既是资源分配的基本单位,又是调度的基本单位,它是系统中并发执行的单元。而在实现了线程的操作系统中,进程是资源分配的基本单位,但线程是调度的基本单位,是系统中并发执行的单元。

引入线程主要有以下4个方面的优点:
(1)易于调度
(2)提高并发现。通过线程可以方便有效地实现并发
(3)开销小。创建线程比创建进程要快,所需的开销也更小
(4)有利于发挥多处理器的功能。通过创建多线程,每个线程都在一个处理器上运行,从而实现应用程序的并行,使每个处理器都得到充分运行。

需要注意的是,尽管线程与进程很相似,但两者也存在着很大的不同,区别如下:
(1)一个线程必定属于也只能属于一个进程;而一个进程可以拥有多个线程并且至少拥有一个线程。
(2)属于一个进程的所有线程共享该线程的所有资源,包括打开的文件、创建的Socket等。不同的进程互相独立。
(3)线程又被称为轻量级进程。进程有进程控制块,线程也有线程控制块。但线程控制块比进程控制块小得多。线程间切换代价小,进程间切换代价大
(4)进程是程序的一次执行,线程可以理解为程序中一段程序片段的执行
(5)每个进程都有独立的内存空间,而线程共享其所属进程的内存空间。

程序、进程与线程的区别是什么

这里写图片描述

线程同步有哪些机制

现在流行的进程线程同步互斥的控制机制,其实是由最原始、最基本的4种方法实现的:临界区、互斥量、信号量和事件。。。

(1)临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。

(2)互斥量:为协调共同对一个共享资源的单独访问而设计。只有拥有互斥对象的线程才有权限去访问系统的公共资源,因为互斥对象只有一个,所以能够保证资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享。

(3)信号量:为控制一个具有有限数量的用户资源而设计。它允许多个线程在同一时刻去访问同一个资源,但一般需要限制同一时刻访问此资源的最大线程数目。

(4)事件:用来通知线程有一些事件已发生,从而启动后继任务的开始。

内核线程和用户线程的区别

根据操作系统内核是否对线程可感知,可以把线程分为内核线程和用户线程。

内核线程建立和销毁都是由操作系统辅助、通过系统调用完成的,操作系统在调度时,参考各进程内的线程运行情况作出调度决定。如果一个进程中没有就绪态的线程,那么这个进程也不会被调度占用CPU。

和内核线程相对应的是用户线程,用户线程指不需要内核支持而在用户程序中实现的线程,其不依赖于操作系统核心,用户进程利用线程库提供创建、同步、调度和管理线程的函数来控制用户线程。用户线程多见于一些历史悠久的操作系统,如UNIX操作系统,不需要用户态/核心态切换,速度快,操作系统内核不知道多线程的存在,因此一个线程阻塞将使得整个进程(包括它的所有线程)阻塞。由于这里的处理器时间片分配是以进程为基本单位的,所以每个线程执行的时间相对减少。为了在操作系统中加入线程支持,采用了在用户控件增加运行库来实现线程,这些运行库被称为“线程包”,用户线程是不能被操作系统所感知的。

引入用户线程有以下4个方面的优势:
(1)可以在不支持线程的操作系统中实现。
(2)创建和销毁线程、线程切换等线程管理的代价比内核线程少的多。
(3)允许每个进程定制自己的调度算法,线程管理比较灵活
(4)线程能够利用的表空间和堆栈空间比内核级线程多。

用户线程的缺点主要有以下两点:
(1)同一进程中只能同时有一个线程在运行,如果有一个线程使用了系统调用而阻塞,那么整个进程都会被挂起。
(2)页面失效也会产生类似的问题

内核线程的优缺点刚好跟用户线程相反。实际上,操作系统可以使用混合的方式来实现线程。

版权声明:本文为博主原创文章,未经博主允许不得转载。

操作系统实验二 进程管理

进程管理一.实验目的 1、 理解进程的概念,明确进程和程序的区别。 2、 理解并发执行的实质。 3、 掌握进程的创建、睡眠、撤销等进程控制方法。 二.实验内容与基本要求 用C语言...
  • u011303443
  • u011303443
  • 2015年11月15日 12:09
  • 5792

操作系统——进程管理

进程管理 4.1 什么是进程 被执行的指令称为代码段。被加工的数据段称为源程序。生成的目标文件也是数据段。 进程是程序的一次执行过程。进程包括数据段和代码段,还有一个进程的控制块PCB。  ...
  • xuyuqingfeng953
  • xuyuqingfeng953
  • 2016年05月30日 20:49
  • 1054

操作系统的课程设计《进程管理》

时间转轮法和最短作业优先算法。先mark一下。 #include #include #include #include #include #include using namespace...
  • modiz
  • modiz
  • 2014年12月25日 17:35
  • 1462

操作系统实验一之进程管理源代码

#include"stdio.h" #include"stdlib.h" #define ready 1 #define run 2   struct pcb {       char name[10...
  • wujiafei_njgcxy
  • wujiafei_njgcxy
  • 2016年10月08日 18:18
  • 2552

浅谈操作系统之进程管理

详解本文前,先来说说什么是操作系统吧,要不,大家可能都不知道自己在看些什么。下图,可以非常形象的表示操作系统及它的相关内容。本文主要详细介绍一下操作系统的进程管理功能。   上图可以看出,操作系统是...
  • sunliduan
  • sunliduan
  • 2014年04月30日 22:41
  • 2212

操作系统的进程管理(c语言模拟)

今天就更一下,模拟进程管理程序。 #include #include #include #include //#define NULL 0 int shumu=0; //进程的内容结构体 str...
  • best_fiends_zxh
  • best_fiends_zxh
  • 2016年10月12日 12:30
  • 2729

linux 进程管理,内存管理,文件系统,系统管理,网络操作概述

进程/线程     进程概念:进程/线程是计算机中最小的执行单元,是实现分时多用户操作系统的基础;那么一个进程在linux中是如何实现的呢?如果熟悉内核就知道内核就是一堆的数据结构,一个进程的所...
  • u012386696
  • u012386696
  • 2014年02月25日 15:18
  • 1530

操作系统 进程管理之进程与线程

一、进程进程是一个具有一定独立功能的程序在一个数据集合上的一次动态执行过程。1、从不同的角度,进程可以有不同的定义,比较典型的定义有: (1)进程是程序的一次执行。 (2)进程是一个程序及其数据在...
  • codeforcer
  • codeforcer
  • 2016年12月09日 10:44
  • 646

学习笔记--操作系统的知识点的概括(思维导图形式)

学习笔记–操作系统将学习操作系统时归纳的一些东西整理出来Mark一下,方便以后回忆和整理 概括对于CS和软工的同学来说。操作系统的重要性就不需要再多说了吧,相当于入门级别的科目了先看一张大概内容的图:...
  • qq_34861102
  • qq_34861102
  • 2017年08月06日 16:24
  • 1352

操作系统概念性题目总结

什么是操作系统?答:操作系统是一种系统软件,是软、硬资源的控制中心。它以尽量合理有效的方法组织单个或多个用户以多任务方式共享计算机的各种资源。资源共享的两种方式?时分和空分。试述多道程序设计的基本思想...
  • qq_27687701
  • qq_27687701
  • 2016年11月26日 23:18
  • 549
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:操作系统:进程管理(概念)
举报原因:
原因补充:

(最多只允许输入30个字)