操作系统学习1

    • 第一章
      • 操作系统做了什么
      • 操作系统的定义和作用
      • 操作系统的特征
      • 典型的系统架构
      • 操作系统的分类

总结自陈向群的视频(18小时)

第一章

操作系统做了什么

C语言执行helloword程序的过程:
用户告诉操作系统执行hellowold程序(例如双击图标,命令形式)
操作系统:找到程序的相关信息,查看是否是可执行文件,并通过程序首部信息确定代码和数据在可执行文件中的位置并计算出对应的磁盘块地址。然后操作系统创建一个新的进程,并将helloworld可执行文件映射到该进程结构,表示由该进程执行helloworld程序。为helloworld程序设置CPU上下文环境,并调到程序开始处。
执行helloworld程序的第一条指令,发生缺页异常;操作系统分配一页物理内存,并将代码从磁盘读入内存,然后继续执行helloworld程序。如果程序过大,会产生多次的缺页异常。
helloworld执行puts函数(系统调用),在显示器上显示字符串。
操作系统找到将字符串送往的显示设备
控制设备的进程告诉设备的窗口系统它要显示的字符串,窗口系统将字符串转换成像素,之后显示

结论:
时而运行的是用户程序,时而运行的是操作系统程序
另一个角度看:进程管理,存储管理, 文件系统共同作用的结果

操作系统的定义和作用

  1. 是一些程序模块的集合,能尽量有效、合理的方式组织和管理计算机的软硬件资源。
    几个关键字:
    有效: 系统效率,资源利用率
    合理:是否公平
    方便使用:用户界面与程序接口

  2. 操作系统的三个功能:

    操作系统是资源的管理者
    怎样管理资源:
    跟踪和记录资源的使用状况,通过相关的数据结构;
    确定资源分配策略(算法)(静态分配策略,动态分配策略(常用))
    实施资源的分配和回收
    提高资源的利用率

    操作系统的五大基本功能:
    进程/线程管理
    存储管理
    文件管理
    设备管理
    用户接口

    操作系统是各种系统服务的提供者
    对机器硬件的扩展:在应用程序与硬件之间建立了一个等价的扩展机器

操作系统的特征

  1. 并发
    指处理多个同时性的活动

    引发的问题:活动切换、保护、相互依赖的活动间的同步

    并行:与并发类似,但多指不同程序同时在多个硬件部件上执行
    例如:并发:跑马拉松(无跑道),100m(有跑道)

  2. 共享
    操作系统与多个用户的程序共同使用计算机系统中的资源
    需要对资源合理分配和使用

    互斥共享(打印机)
    同时共享(磁盘文件)
    带来问题:怎么使用最优化

  3. 虚拟
    一个物理实体映射为若干个对应的逻辑实体(分时或者分空间)
    目的为了提高资源利用率

    CPU:每个进程的“虚处理机”
    存储器:每个进程都有独立的虚拟地址空间(代码+数据+堆栈)
    显示设备:多窗口或虚拟终端

  4. 随机
    操作系统必须随时对以不可预测的次序发生的事件进行相应并处理

典型的系统架构

  1. Windows架构 内核态 用户态
  2. UNIX架构
  3. LINUX
  4. ANDROID

操作系统的分类

  1. 传统操作系统的分类

    批处理操作系统
    作业会组成一批作业,输入到计算机中,在系统中形成一个自动转接的连续的作业流,操作系统自动、依次执行每个作业
    提高利用率,增加吞吐量
    作业包括:用户程序 数据 作业说明书(作业控制语言编写)
    成批:不能干预
    问题:输入输出时,CPU处于等待状态
    分为:单道批处理系统;多道批处理系统
    SPOOLing技术(打印机仍在使用)

    分时系统
    操作系统将CPU时间划分为若干个片段,称为时间片

    实时操作系统
    是指计算机能及时响应外部事件的请求
    第一类:实时过程控制
    第二类:实时通信处理
    最关键的参数:时间
    硬实时系统、软实时系统(按时间严格程度)

    个人云计算操作系统

    网络操作系统

    分布式操作系统

    嵌入式操作系统

你可能感兴趣的:(操作系统学习1)