操作系统(五)文件系统和I/O系统

news2025/1/20 19:12:29

文章目录

    • 前言
    • 文件系统
      • 文件系统和文件
      • 文件描述符
      • 目录、文件别名和文件系统
        • 分层文件系统
        • 目录实现
        • 文件别名
        • 名字解析(路径遍历)
        • 文件系统挂载
        • 文件系统种类
      • 虚拟文件系统
      • 文件缓存和打开文件
        • 打开文件
      • 文件分配
      • 空闲空间管理和冗余磁盘阵列RAID
        • 空闲空间管理
        • 冗余磁盘阵列RAID(Redundant Array of Indexpensive Disks)
    • I/O系统
      • 同步与异步I/O
      • I/O结构
      • I/O控制方式
      • I/O数据传输
      • 磁盘调度
        • 1. 先进先出FIFO算法
        • 2. 最短服务时间优先(SSTF)
        • 3. 扫描算法(SCAN)(电梯算法)
        • 4. 循环扫描算法(C-SCAN)
        • 5. LOOK与C-LOOK算法
        • 6. N步扫描(N-step-SCAN)算法
        • 7. 双队列扫描算法(FSCAN)算法
      • 磁盘缓存
    • 小结

前言

本文主要涉及操作系统的简介、硬件结构、内存管理、进程管理、文件系统、设备管理等内容,可以作为学习操作系统的辅助文本记录。撰写本文的目的主要是针对操作系统整体做一个相对完整的梳理,以便后续回顾之用。
本文是第五篇,讲述操作系统的文件系统和I/O系统。
第一篇:操作系统(一)基础知识及操作系统启动
第二篇:操作系统(二)内存管理的基础知识
第三篇:操作系统(三)进程和线程的基础知识
第四篇:操作系统(四)进程和线程的调度算法、同步互斥、通信、死锁等

文件系统

文件系统和文件

文件系统:操作系统中管理持久性数据的子系统,提供数据存储和访问功能

  1. 组织、检索、读写访问数据
  2. 大多数计算机系统都有文件系统
  3. Google也是一个文件系统

文件:具有符号名,由字节序列构成的数据项集合

文件系统的功能:

  1. 分配文件磁盘空间

    管理文件块(位置和顺序)

    管理空闲空间(位置)

    分配算法(策略)

  2. 管理文件集合

    定位:文件及其内容

    命名:通过名字找到文件

    文件系统结构:文件组织方式

  3. 数据可靠和安全

    安全:多层次保护数据安全

    可靠:持久保存文件;避免系统泵快、媒体错误、攻击等

文件属性:

  1. 名称、类型、位置、大小……

  2. 文件头:文件系统元数据中的文件信息

    文件属性

    文件存储位置和顺序

文件描述符

  • 文件描述符:操作系统在打开文件表中维护的打开文件状态和信息
    • 文件指针:最近一次读写位置;每个进程分别维护自己的 打开文件指针
    • 文件打开计数:当前文件打开的次数;最后一个打开该文件的进程关闭文件时,就可以将其从文件表中去除了。
    • 文件在磁盘上位置:缓存数据访问信息
    • 访问权限:每个进程的文件访问模式信息
  • 文件的用户视图
    • 持久的数据结构
  • 系统访问接口
    • 字节序列的集合(UNIX)
    • 系统不关心存储磁盘上的数据结构
  • 操作系统的文件视图
    • 数据块的集合
    • 数据块是逻辑存储单元,而扇区是物理存储单元
  • 进程读文件
    • 获取字节所在的数据块
    • 返回数据块内对应部分
  • 进程写文件
    • 获取数据块
    • 修改数据块中对应部分
    • 写回数据块
  • 文件系统中的基本操作单位是数据块
  • 访问模式:
    • 顺序访问:按字节依次读取
    • 随机访问:从中间读写
    • 索引访问:依据数据特征索引
  • 文件内部结构
    • 无结构:字节序列
    • 简单记录结构:分列、固定长度、可变长度等
    • 复杂结构:可执行文件、PDF等
  • 文件共享和访问控制
    • 多用户系统的文件共享是很必要的
    • 访问控制:每个用户能够获得哪些文件的哪些访问权限
      • 访问模式:读、写、执行等

目录、文件别名和文件系统

分层文件系统
  • 文件是以目录的方式组织起来

  • 目录是一类特殊的文件

    目录的内容是文件的索引表<文件名,指向文件的指针>

  • 目录和文件的树形结构

    早期的文件系统是扁平的(只有一层目录)

  • 典型目录操作

    搜索文件、创建文件、删除文件、列目录、重命名文件、遍历路径

  • 操作系统应该只允许内核修改目录

    确保映射的完整性

    如果用户希望修改目录,只能通过系统调用访问目录

目录实现
  • 文件名的线性列表,包含指向数据块的指针

    编程简单,但执行耗时

  • 哈希表,哈希数据结构的线性表

    减少目录搜索时间

文件别名
  • 两个或多个文件名关联同一个文件
  • 实现:
    • **硬链接:**多个文件项指向一个文件(硬链接不可以跨系统,只有删除文件的所有硬链接和源文件时,系统才会彻底删除该文件。)
    • **软链接:**以“快捷方式”指向其他文件,通过存储真实文件的逻辑名称来实现。(软链接相当于重新创建一个文件,该文件的内容是另一个文件的路径,所以访问软链接的时候,相当于访问到了另外一个文件,所以软链接是可以跨文件系统的,甚至目标文件被删除了,链接文件都还在,只不过指向的文件找不到了。)
名字解析(路径遍历)

名字解析:把逻辑名字转换为物理资源(如文件)

  1. 依据路径名,在文件系统中找到实际文件位置
  2. 遍历文件目录直到找到目标文件
  • 举例:解析“/bin/ls”

    • 读取根目录的文件头(在磁盘固定位置)
    • 读取根目录的数据块,搜索“bin"项
    • 读取bin的文件头
    • 读取bin的数据块;搜索“ls”项
    • 读取ls的文件头
  • 当前工作目录(PWD)

    • 每个进程都会指向一个缺省的文件目录用于解析文件名

    • 允许用户指定相对路径来代替绝对路径

      如, 用PWD = "/bin"能够解析“ls”.

文件系统挂载
  • 文件系统必须先挂载才能被访问;
  • 没有挂载的文件系统被挂载在挂载点上
文件系统种类
  • 磁盘文件系统
    • 文件存储在数据存储设备上,如磁盘;
    • 例如:FAT,NTFS, ext2/3,ISO9660等
  • 数据库文件系统
    • 文件特征是可以被寻址(辨识)的
    • 如WinFS
  • 日志文件系统
    • 记录文件系统的修改/事件
  • 网络/分布式文件系统
    • NFS,SMB,AFS,GFS等
  • 特殊/虚拟文件系统

虚拟文件系统

是为了面对多种文件系统,但是希望提供一个统一的文件访问和文件控制的接口

  • 分层结构
    • 虚拟(逻辑)文件系统(VFS, Virtual File System)
    • 特定文件系统模块

  • 功能
    • 提供相同的文件和文件系统接口
    • 管理所有文件和文件系统关联的数据结构
    • 高效查询例程,遍历文件系统
    • 与特定文件系统模块的交互
  • 基本数据结构
    • 文件卷控制块(Unix: “Superblock”)
      • 每个文件系统一个
      • 文件系统详细信息
      • 块、块大小、空余块、计数\指针等
    • 文件控制块(Unix: “vnode” or “inode”)
      • 每个文件一个
      • 文件详细信息
      • 访问权限、拥有者、大小、数据块位置等
    • 目录项(Linux: “dentry”)
      • 每个目录项一个(目录和文件)
      • 将目录项数据结构及树型布局编码成树型数据结构
      • 指向文件控制块、父目录、子目录等

文件缓存和打开文件

打开文件
  • 文件描述符:每个打开的文件都有一个文件描述符
  • 文件描述信息:目录项、当前文件指针、文件操作设置等
  • 打开文件表:
    • 每个进程都有一个进程打开文件表;
    • 有一个系统级的打开文件表
    • 有文件被打开时,文件卷就不能被卸载
  • 打开文件锁
    • 一些文件系统提供文件锁,用于协调多进程的文件访问
    • 强制:根据锁保持情况和访问需求确定 是否拒绝访问
    • **劝告:**进程可以查找锁的状态来决定怎么做

文件分配

  • 文件大小

    • 大多数文件都很小
      • 需要对小文件提供很好的支持
      • 块空间不能太大
    • 一些文件非常大
      • 必须支持大文件
      • 大文件访问需要高效
  • 文件分配:如何表示分配给一个文件数据块的位置和顺序

  • 分配方式:连续分配、链式分配、索引分配

  • 指标:

    存储效率:外部碎片等

    读写性能:访问速度等

  1. 连续分配
  • 优点:文件读取表现好,高效的顺序和随机访问
  • 缺点:碎片和文件增长问题,文件增加怎么办?预先多分配?还是整体迁移?
  1. 链式分配
  • 优点:创建、增加、缩小很容易;没有碎片
  • 缺点:无法实现真正的随机访问,可靠性差,破坏一个指针,后面的数据都丢失了
  1. 索引分配
  • 为每一个文件创建一个索引数据块,里面包含了指向文件数据块的指针列表
  • 优点:创建、增大、缩小很容易,没有碎片;支持直接访问
  • 缺点:文件很小时,索引开销相对大;大文件的表示怎么办?可能一个索引块不够用
  1. 大文件的索引分配
  • 链式索引块
  • 多级索引块
  1. 实际的UFS多级索引分配
  • 数据少的时候,直接对应数据块;

  • 数据大的话,增加索引块,一级索引,二级索引,……

  • 效果:

    提高了文件大小限制阈值;

    动态分配数据块,文件扩展很容易

    小文件开销小;

    为大文件间接分配数据块,但查询速度会有所下降

空闲空间管理和冗余磁盘阵列RAID

空闲空间管理
  • 跟踪记录文件卷中未分配的数据块
  1. 位图
  • 用位图代表空闲数据块列表,0为空闲,1为已分配

  • 使用简单但可能会是一个很大的向量表

    160GB—40M数据块–5MB位图

    查找空闲块的时间长

  1. 链表

  2. 链式索引

冗余磁盘阵列RAID(Redundant Array of Indexpensive Disks)

文件卷:一个拥有完整文件系统实例的外存空间通常常驻在磁盘的单个分区上

冗余磁盘阵列是磁盘管理技术

实现:

  • 软件:操作系统内核的文件卷管理
  • 硬件:RAID硬件控制器(I/O)
  1. RAID-0:磁盘条带化

把数据块分成多个子块,存储在独立的磁盘中

通过独立磁盘上并行数据块访问提供更大的磁盘带宽

  1. RAID-1: 磁盘镜像

向两个磁盘写入,从任何一个读取

可靠性成倍增长;读取性能 线性增加

  1. RAID-4:带校验的磁盘条带化

数据块级的磁盘条带化加专用奇偶校验磁盘;允许从任意一个故障磁盘中恢复

  1. RAID-5: 带分布式校验的磁盘条带化

校验和分散,降低校验和磁盘的读写压力

  1. RAID嵌套

上面的几种组合使用,如RAID0+1,并行并且可靠性增加

I/O系统

  1. 字符设备: 键盘/鼠标、串口等

    访问特征:以字节为单位顺序访问

  2. **块设备:**磁盘驱动器,磁带驱动器,光驱等

    访问特征:以数据块为基本访问单位,数据访问均匀

  3. **网络设备:**以太网、无线、蓝牙等

    访问特征:格式化报文交换,比较复杂

同步与异步I/O

  1. 阻塞I/O:wait要等待;‘
  • 读数据(read)时,进程将进入等待状态,直到完成数据读出;
  • 写数据(write)时,进程将进入等待状态,直到设备完成数据写入;
  1. 非阻塞I/O:Don’t wait不等待;
  • 立即从read/write系统调用中返回,返回值为成功传输的字节数;
  • read/write的传输字节数可能为0;
  1. 异步I/O:Tell me Later
  • 读数据时,使用指针标记好用户缓冲区,立即返回,稍后内核将填充缓冲区并通知用户;
  • 写数据时,使用指针标记好用户缓冲区,立即返回;稍后内核将处理数据并通知用户;

I/O结构

I/O控制方式

每种设备都有一个设备控制器,控制器相当于一个小 CPU,它可以自己处理一些事情,当 CPU 给设备发送了一个指令,让设备控制器去读设备的数据,读完如何通知CPU?

  1. 轮询等待

    控制器的寄存器一般会有状态标记位,用来标识输入或输出操作是否完成,,让 CPU 一直查寄存器的状态,直到状态标记为完成。显然CPU浪费了相当多时间。

  2. 中断

    设备完成任务后触发中断到中断控制器,中断控制器就通知 CPU,一个中断产生了,CPU 需要停下当前手里的事情来处理中断。

  3. DMA(Direct Memory Access

    中断的方式对于频繁读写数据的磁盘,并不友好,这样 CPU 容易经常被打断,会占用 CPU 大量的时间。DMA可以使得设备在 CPU 不参与的情况下,能够自行完成把设备 I/O 数据放入到内存。那要实现 DMA 功能要有 「DMA 控制器」硬件的支持。

Q: DMA是什么?

A: DMA(Direct Memory Access,直接内存存取)是计算机系统中一种用于高效地进行数据传输的技术。DMA允许外部设备(如硬盘驱动器、网络适配器等)直接和系统内存进行数据传输,而无需通过中央处理器(CPU)的干预,从而提高了系统的整体性能和效率。

在没有使用DMA的情况下,数据传输通常需要通过CPU来完成,这意味着CPU必须参与每一个数据传输操作,即使这些操作与CPU的主要任务无关。这样会占用CPU的时间和资源,并降低系统的整体性能。

而有了DMA技术,外部设备可以直接和系统内存进行数据传输,而无需CPU的直接参与。DMA控制器负责管理数据的传输过程,它可以独立地访问系统内存,读取或写入数据,而无需CPU的干预。这样一来,CPU就可以专注于执行其他任务,从而提高了系统的并发性和整体性能。

DMA 的工作方式如下:

  • CPU 需对 DMA 控制器下发指令,告诉它想读取多少数据,读完的数据放在内存的某个地方就可以了;
  • 接下来,DMA 控制器会向磁盘控制器发出指令,通知它从磁盘读数据到其内部的缓冲区中,接着磁盘控制器将缓冲区的数据传输到内存;
  • 当磁盘控制器把数据传输到内存的操作完成后,磁盘控制器在总线上发出一个确认成功的信号到 DMA 控制器;
  • DMA 控制器收到信号后,DMA 控制器发中断通知 CPU 指令完成,CPU 就可以直接用内存里面现成的数据了;

可以看到, CPU 当要读取磁盘数据的时候,只需给 DMA 控制器发送指令,然后返回去做其他事情,当磁盘数据拷贝到内存后,DMA 控制机器通过中断的方式,告诉 CPU 数据已经准备好了,可以从内存读数据了。仅仅在传送开始和结束时需要 CPU 干预

I/O数据传输

  • 程序控制I/O(PIO, Programmed I/O)
    • 通过CPU的in/out或者load/store传输所有数据
    • 特点:硬件简单、编程容易;消耗的CPU时间和数据量成正比
    • 适用于简单的、小型的设备I/O
  • 直接内存访问(DMA)
    • 设备控制器可以直接访问系统总线
    • 控制器直接与内存互相传输数据
    • 特点:设备传输数据不影响CPU; 需要CPU参与设置
    • 适用于高吞吐量I/O

操作系统需要了解设备状态

  • I/O操作完成时间

  • I/O操作遇到错误

  • 两种方式:轮询和设备中断

  1. 轮询
  • I/O设备在特定的状态寄存器中放置状态和错误信息
  • 操作系统定期检测状态寄存器
  • 特点:
    • 简单
    • I/O操作频繁或不可预测时,开销大和延时长
  1. 设备中断
  • CPU在I/O之前设置任务参数
  • CPU发出I/O请求后,继续执行其他任务;
  • I/O设备处理I/O请求
  • I/O设备处理完成后,出发CPU中断请求
  • CPU接收中断,分发到相应中断处理例程
  • 特点:
    • 处理不可预测事件效果好
    • 开销相对较高
  1. 一些设备可能结合了轮询和设备中断
  • 高宽带网络设备(数据多,量大)
    • 第一个传入数据包到达前采用中断
    • 轮询后面的数据包直到硬件缓存为空

磁盘调度

磁盘工作机制

  1. 读取或写入时,磁头必须被定位在期望的磁道,并从所期望的柱面和扇区开始
  2. 寻道时间:定位到期望的磁道所花费的事件
  3. 旋转延迟:从零扇区开始处到达目的地所花费的时间

平均旋转延迟时间=磁盘旋转一周时间的一半

磁盘调度算法:

  1. 寻道时间是磁盘访问最耗时的部分;
  2. 同时会有多个在同一磁盘上的I/O请求;
  3. 随机处理磁盘访问请求的性能表现很差
1. 先进先出FIFO算法

先来先服务(First-Come,First-Served,FCFS),顾名思义,先到来的请求,先被服务。这种算法,比较简单粗暴,但是如果大量进程竞争使用磁盘,请求访问的磁道可能会很分散,那先来先服务算法在性能上就会显得很差,因为寻道时间过长。

2. 最短服务时间优先(SSTF)

最短寻道时间优先(Shortest Seek First,SSF)算法的工作方式是,优先选择从当前磁头位置所需寻道时间最短的请求。

98,183,37,122,14,124,65,67

那么,那么根据距离磁头( 53 位置)最近的请求的算法,具体的请求则会是下列从左到右的顺序:

65,67,37,14,98,122,124,183

这个算法可能存在某些请求的饥饿,因为本次例子我们是静态的序列,看不出问题,假设是一个动态的请求,如果后续来的请求都是小于 183 磁道的,那么 183 磁道可能永远不会被响应,于是就产生了饥饿现象,这里产生饥饿的原因是磁头在一小块区域来回移动

3. 扫描算法(SCAN)(电梯算法)

磁头在一个方向上移动,访问所有未完成的请求,直到磁头到达该方向上的最后的磁道,才调换方向,这就是扫描(Scan)算法

扫描调度算法性能较好,不会产生饥饿现象,但是存在这样的问题,中间部分的磁道会比较占便宜,中间部分相比其他部分响应的频率会比较多,也就是说每个磁道的响应频率存在差异。

4. 循环扫描算法(C-SCAN)

循环扫描(Circular Scan, CSCAN )规定:只有磁头朝某个特定方向移动时,才处理磁道访问请求,而返回时直接快速移动至最靠边缘的磁道,也就是复位磁头,这个过程是很快的,并且返回中途不处理任何请求,该算法的特点,就是磁道只响应一个方向上的请求

循环扫描算法相比于扫描算法,对于各个位置磁道响应频率相对比较平均.

5. LOOK与C-LOOK算法

针对 SCAN 算法的优化则叫 LOOK 算法,它的工作方式,磁头在每个方向上仅仅移动到最远的请求位置,然后立即反向移动,而不需要移动到磁盘的最始端或最末端,反向移动的途中会响应请求

针对 C-SCAN 算法的优化则叫 C-LOOK,它的工作方式,磁头在每个方向上仅仅移动到最远的请求位置,然后立即反向移动,而不需要移动到磁盘的最始端或最末端,反向移动的途中不会响应请求

6. N步扫描(N-step-SCAN)算法
  • 磁盘粘着(Arm Stickiness)现象

    SSTF、SCAN以及CSCAN等算法中,可能出现磁头停留在某处不动的情况(因为一直在响应附近的请求)

  • N步扫描算法:

    1. 将磁盘请求队列分成长度为N的子队列
    2. 按照FIFO算法依次处理所有子队列
    3. 按照扫描算法处理每个子队列
7. 双队列扫描算法(FSCAN)算法
  • FSCAN算法是N步扫描算法的简化,只是将磁盘请求队列分成两个子队列
  • 将磁盘I/O请求分成两个子队列
  • 交替使用扫描算法处理一个队列
  • 新生成的磁盘I/O请求放入另一队列中,所有的新请求都被推迟到下一次扫描时处理

磁盘缓存

缓存:数据传输双方访问速度差异较大时,引入的速度匹配中间层

磁盘缓存是磁盘扇区在内存中的缓存区

  • 磁盘缓存的调度算法很类似虚拟存储调度算法
  • 磁盘的访问频率远远低于虚拟存储的内存访问频率

单缓存(single Buffer Cache)

双缓存(Double Buffer Cache)

小结

本节主要操作系统的进程和线程的调度算法、同步互斥、通信、死锁等。
本主要文参考:

  1. 《操作系统》–清华大学网课
  2. 小林coding

如果您觉得我写的不错,麻烦给我一个免费的赞!如果内容中有错误,也欢迎向我反馈。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1215202.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

小程序游戏、App游戏与H5游戏:三种不同的游戏开发与体验方式

在当今数字化的时代&#xff0c;游戏开发者面临着多种选择&#xff0c;以满足不同用户群体的需求。小程序游戏、App游戏和H5游戏是三种流行的游戏开发和发布方式&#xff0c;它们各自具有独特的特点和适用场景。 小程序游戏&#xff1a;轻巧便捷的社交体验 小程序游戏是近年来…

为什么都说学医的转行网络安全行业更容易些?

网络系统坏了&#xff0c;被入侵破坏了&#xff0c;找安全工程师防护修补。如果没有修好&#xff0c;我可以不给钱&#xff0c;再找一家能修好的。但是看病就不一样了&#xff0c;就算医生没有给我治好病&#xff0c;也照样要收医疗费。 这样的类比乍一听上去好像挺有道理&…

解析:什么是生成式AI?与其他类型的AI有何不同?

原创 | 文 BFT机器人 快速浏览一下头条新闻&#xff0c;你会发现生成式AI似乎无处不在。事实上&#xff0c;一些新闻标题甚至可能是通过生成式AI编写的&#xff0c;例如OpenAI旗下的ChatGPT&#xff0c;这个聊天机器人已经展现出了生成看起来像人类所写文本的惊人能力。 当人们…

蓝桥杯每日一题2023.11.16

蓝桥杯大赛历届真题 - C 语言 B 组 - 蓝桥云课 (lanqiao.cn) 题目描述 对于此代码&#xff0c; 注释解释如下&#xff1a;答案&#xff1a;f(a,k1,m-j,b)&#xff1b; 在这里插入代码片#include <stdio.h> #define N 6 #define M 5 #define BUF 1024 void f(int a[], in…

市场研究报告:量子计算将颠覆银行业!

&#xff08;图片来源&#xff1a;网络&#xff09; 量子银行将对金融体系产生重大影响&#xff0c;它在量子计算和区块链的基础上建立了一个更快的支付机制&#xff0c;并且通过消除传统点对点支付中常见的中间人&#xff0c;降低了运营成本。 量子计算及其运作机制 中东地区…

【人工智能实验】遗传算法求解旅行商问题 golang

人工智能经典问题旅行商求解 使用遗传算法求解&#xff0c;算法流程如下&#xff1a; 读取所有的城市坐标&#xff0c;记作集合initCitys生成popSize个种群&#xff0c;记为pops取出种群中适应度最高的&#xff0c;记作rank0使用轮盘算法&#xff0c;从rank0中选出eliteSize个…

Redis分布式锁(中)

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 我们在不久前介绍了Spr…

【场景】高并发解决方案

文章目录 1. 硬件2. 缓存2.1 HTTP缓存2.1.1 浏览器缓存2.1.2 Nginx缓存2.1.3 CDN缓存 2.2 应用缓存 3 集群4. 拆分4.1 应用拆分&#xff08;分布式、微服务&#xff09;4.2 数据库拆分 5. 静态化6. 动静分离7. 消息队列8. 池化8.1 对象池8.2 数据库连接池8.3 线程池 9. 数据库优…

酷开系统 酷开科技,将家庭娱乐推向新高潮

在当今数字化时代&#xff0c;家庭娱乐已经成为人们日常生活中不可或缺的一部分。如果你厌倦了传统的家庭娱乐方式&#xff0c;想要一种全新的、充满惊喜的娱乐体验&#xff0c;那么&#xff0c;不妨进入到酷开科技的世界&#xff0c;作为智能电视行业领军企业&#xff0c;酷开…

Git常用操作-MD

文章目录 1. 本地创建分支&#xff0c;编写代码&#xff0c;提交本地分支到远程仓库2. 提交本地代码到本地仓库3. 提交本地代码到本地dev分支4. 提交本地dev分支到远程仓库5. 本地dev分支拉取远程master分支&#xff0c;并将master分支内容合并到本地dev6. 同义命令7. 撤销上次…

Codeforces Round 908 (Div 2——AB)

A. Secret Sport 题目 AB二人玩游戏&#xff0c;每一局&#xff08;plays&#xff09;游戏会有一个获胜者&#xff0c;首先获胜X局&#xff08;play&#xff09;的玩家得一分&#xff08;赢得一轮sets&#xff09;。率先获得Y分的玩家获得最终胜利。 给你整场游戏的每局&…

Spring Boot使用EhCache完成一个缓存集群

在上一篇在SpringBoot中使用EhCache缓存&#xff0c;我们完成了在Spring Boot中完成了对EhCaChe的使用&#xff0c;这篇&#xff0c;我们将对EhCache的进一步了解&#xff0c;也就是搭建一个EhCache的缓存集群。 集群 在搭建一个EhCache的时候&#xff0c;我们需要先了解&…

areadetector ADURL模块应用在面探测控制的初步应用

本章中讨论了使用ADURL控制面探测器Lambda的过程&#xff1a; ADURL的使用请见&#xff1a; EPICS -- areaDetector URL驱动程序-CSDN博客 需要启动一个ADURL的IOC程序&#xff0c;并且设置相关的插件中参数的值&#xff1a; # st.cm < envPaths < st_base.cmddbpf 1…

WorkPlus即时通讯app支持多种信创环境组合运行

在信息技术领域&#xff0c;国产信创技术的快速发展为企业带来了更多的选择和机会。在此背景下&#xff0c;WorkPlus作为一款全方位的移动数字化平台&#xff0c;全面支持国产信创操作系统、芯片和数据库&#xff0c;并且全面兼容鸿蒙操作系统。这一优势使得WorkPlus成为了企业…

企业数据备份应该怎么操作?应该知道的四种备份方法

​企业数据备份对于保护最重要的资产至关重要。在面对不断增加的安全威胁时&#xff0c;很多企业都感到无从下手&#xff0c;不知如何保护关键业务数据。通过采用正确的数据备份方法&#xff0c;可以成为确保企业数据安全的最有效手段。因此&#xff0c;不论您是个人还是在职人…

第二证券:今日投资前瞻:小米汽车引关注 全球风光有望持续高速发展

昨日&#xff0c;两市股指盘中轰动上扬&#xff0c;深成指、创业板指一度涨超1%。到收盘&#xff0c;沪指涨0.55%报3072.83点&#xff0c;深成指涨0.72%报10077.96点&#xff0c;创业板指涨0.53%报2015.36点&#xff0c;北证50指数涨2.64%&#xff1b;两市算计成交9900亿元&…

亚马逊云科技云存储服务指南

文章作者&#xff1a;Libai 高效的云存储服务对于现代软件开发中的数据管理至关重要。亚马逊云科技云存储服务提供了强大的工具&#xff0c;可以简化工作流程并增强数据管理能力。 亚马逊云科技开发者社区为开发者们提供全球的开发技术资源。这里有技术文档、开发案例、技术专栏…

Ubuntu 22.04 LTS ffmpeg mp4 gif 添加图片水印

ffmpeg编译安装6.0.1&#xff0c;参考 Ubuntu 20.04 LTS ffmpeg gif mp4 互转 许编译安装ffmpeg &#xff1b;解决gif转mp4转换后无法播放问题-CSDN博客 准备一个logo MP4添加水印 ffmpeg -i 2.mp4 -vf "movielogo.png[watermark];[in][watermark]overlayx10:y10[out]&…

torch_cluster、torch_scatter、torch_sparse三个包的安装

涉及到下面几个包安装的时候经常会出现问题&#xff0c;这里我使用先下载然后再安装的办法&#xff1a; pip install torch_cluster pip install torch_scatter pip install torch_sparse 1、选择你对应的torch版本&#xff1a;https://data.pyg.org/whl/ 2、点进去然后&…

PowerConsume功耗计算器

嵌入式低功耗产品开发&#xff0c;功耗计算器资源-CSDN文库 PowerConsume使用说明 安装说明 需要安装在无空格等特殊字符的路径&#xff0c;不推荐安装在C盘。 功能说明 已知条件 电池容量 各状态的电流和运行时间 自动计算出设备运行时间 启动界面如下 添加状态 在空白处…