计算机底层知识

news2025/1/16 21:13:08

汇编语言(机器语言)的执行过程

汇编语言的本质:机器语言的助记符 其实他就是机器语言

计算机通电->CPU读取内存中程序(电信号输入)

->时钟发生器不断震荡通电 ->推动CPU内部一步一步执行(执行多少步取决于指令需要的时钟周期)

->计算完成 ->写回(电信号)->写给显卡输出(打印或者图形) 

CPU的基本组成

PC-> Program Counter 程序计数器 (记录当前指令地址)

Registers -> 暂时存储CPU计算需要用到的数据 (记存器)

ALU -> Arithmetic & Logic Unit 运算单元

CU -> Control Unit 控制单元

MMU -> Memory Management Unit 内存管理单元

缓存

缓存行:

缓存行越大,局部性空间效率越高,但读取时间慢

缓存行越小,局部性空间效率越低,但读取时间快

取一个折值,目前多用:64字节

缓存行对齐:对于有些特别敏感的数字,会存在线程高竞争的访问,为了保证不发生伪共享,可以使用缓存行对齐的编程方式

JDK7中,很多采用long padding提高效率

JDK8,加入了@Contened注解(实验)需要加上:-JVM -XX:-RestrictContended

乱序执行

CPU层面如何禁止重排序?

答:内存屏障 (对某部分内存做操作时前后添加的屏障,屏障前后的操作不可以乱序执行)

禁止乱序

cpu层面:inter ->原语(mfence ifence sfence)或者锁总线

jvm层级:8个hanppens-before原则,4个内存屏障 (LL LS SL SS)

as-if-serial:不管硬件什么顺序,单线程执行的结果不变,看上去像是serial

volatile的实现细节

JVM层面:

StoreStorBarier   volatile写操作    StoreLoadBarrier

LoadLoadBarrier  volatile读操作   LoadStoreBarrier

合并写 (不重要)

Write Combining Buffer

一般是四个字节

由于ALU速度太快,所以在写入L1的同时,写入一个WC Buffer,满了之后,再直接更新到L2

 NUMN

Non Uniform Memory Access

ZGC- NUMA aware

分配内存会优先分配该线程所在CPU的最近内存,可以显著提高效率,也可以访问其他内存,只不过效率较慢

启动过程(不重要)

通电-> bios uefi 工作 ->自检 -> 到硬盘固定位置加载bootloder -> 读取可配置信息 -> CMOS

                                                        

                                          OS基础

内核分类

微内核 - 弹性部署 5G loT

宏内核 - PC phone

外核 - 科研 实验中 为应用定制操作系统(多租户 request-basedGC JVM)

用户态与内核态

cpu分不同的指令级别

linux内核跑在ring 0级,用户程序跑在ring3,对于系统的关键访问,需要经过kernel的同意,保证系统健壮性

内核执行的操作 -> 200多个系统调用 sendfile read write pthread fork

JVM -> 站在OS的角度,就是一个普通程序

                                进程 线程 纤程 中断

面试高频:进程和线程有什么区别?

答案:进程就是一个程序运行起来的状态,线程是一个进程中的不同的执行路径。

专业回答:进程是OS分配资源的基本单位,线程是执行调度的基本单位。分配资源最重要的是:独立的内存空间,线程调度执行(线程共享进程的内存空间,没有独立的内存空间)

纤程:用户态的线程,线程中的线程,切换和调度不需要经过OS

优势:

  1.  占有资源很少OS:线程1M Fiber :4K
  2. 切换比较简单
  3. 启动很多个10w+

目前2020 3 22支持内置纤程的语言:Kotin Scala GO Python(lib)...   Java?(open jdk:loom)

Java中对于纤程的支持:没有内置,盼望内置

利用Quaser库 (不成熟)

纤程的应用场景

纤程 VS 线程池 :很短的计算任务,不需要和内核打交道,并发量高

进程

linux中也称为task,是系统分配资源的基本单位

资源:独立的地址空间 内核数据结构 (进程描述符...)全局变量 数据段...

进程描述符: PCB (Process Control Block)

什么是僵尸线程

        ps-ef | grep defuct 父进程产生子进程后,会维护进程的一个PCB结构,子进程退出,由父进程释放,如果父进程没有释放,那么子进程成为一个僵尸进程

什么是孤儿线程

        子进程结束之前,父进程已经退出,孤儿进程会成init进程的孩子,由1号进程维护 orphan.c

        

进程调度

2.6采用CFS调度策略:Completely Fair Scheduler

按优先级分配时间片的比例,记录每个进程的执行时间,如果有一个进程执行时间不到他应该分配的比例,优先执行

默认调度策略:

实时进程:(急诊)优先级分高低 - FIFO (First In First Out),优先级一样 - RR(Round Robin)

普通进程:CFS

中断

硬件跟操作系统内核打交道的一种机制

软中断(80中断)== 系统调用

系统调用: int 0x80 或者 sysenter原语通过ax寄存器填入调用号

参数通过bx cx dx si di传入内核返回值通过ax返回

java读网络 - jvm read() - c库read() - >内核空间 -> system_call() (系统带哦有处理程序) -> sys_read()

                                           内存管理

内存管理的发展历程

DOS时代 - 同一时间只能有一个进程在运行(也有一些特殊算法可以支持多线程)

windows9x - 多个进程装入内存 (问题)1:内存不够用  2:互相打扰

为了解决这两个问题,诞生了现在的内存管理系统:虚拟地址 分页装入 软硬件结合寻址

1.分页,内存中分成固定大小的页框(4k),把程序(硬盘上)分成4K大小的块,用到哪一块,加载哪一块,加载的过程中,如果内存已经满了,会把最不常用的一块分区放到swap分区,把最新的一块加载进来,这个就是著名的LRU算法 (力扣146题)

2.虚拟内存(解决相互打扰问题)

  1. DOS Win31 ...
  2. 为了保证互不影响 - 让进程工作在虚拟空间,程序中用到的空间地址不再是直接的物理地               址,而是虚拟的地址,这样,A进程永远不可能访问到B进程的空间
  3. 虚拟空间多大呢?寻址空间 - 64位置 2^64,比物理空间大很多,单位是byte
  4. 站在虚拟的角度,进程是独享整个系统 + CPU
  5. 内存映射:偏移量 + 段的基地址 = 线性地址 (虚拟空间)
  6. 线性地址通过OS + MMU (硬件 Memory Management Unit)

3.缺页中断

        1.需要用到页面内存中没有,产生缺页异常(中断),由内核处理并加载

为什么使用虚拟内存?

•隔离应用程序
-每个程序都认为自己有连续可用的内存
-突破物理内存限制
-应用程序不需要考虑物理内存是否够用,是否能够分配等底层问题

•安全
-保护物理内存,不被恶意程序访问

ZGC

算法叫做 : Colored Pointer

GC信息记录在指针是,不是记录在头部,immediate memory use

42位指针 寻址空间4T JDK13 -> 16T 目前为止最大16T (2^44)

CPU如何区分一个立即数和一条指令

总线内部分为:数据总线 地址总线 控制总线

地址总线目前:48位

                                内核同步机制

关于同步理论的一些基本概念

  • 临界区(critical area):访问或操作共享数据的代码段。简单理解:synchronized大括号中部分(原子性)
  • 竞争条件(race conditions)两个线程同时拥有临界区的执行权
  • 数据不一致:data unconsistency 由竞争条件引起的数据破坏
  • 同步(synchronization)避免race conditions
  • 锁:完成同步的手段(门锁,门后是临界区,只允许一个线程存在)
  • 上锁解锁必须具备原子性
  • 原子性(象原子一样不可分割的操作)
  • 有序性(禁止指令重排)
  • 可见性(一个线程内的修改,另一个线程可见)
  • 互斥锁,排它锁,共享锁,分他锁

 内核同步常用方法

  1. 原子操作-内核中类似于AtomicXXX,位于<linux/types.h>
  2. 自旋锁-内核中通过汇编支持的cas,位于<asm/spinlock.h>
  3. 读-写自旋-类似于ReadWriteLock,可同时读,只能一个写读的时候是共享锁,写的时候是排他锁
  4. 信号量-类似于Semaphore(PV操作 down up操作 占有和释放)重量级锁,线程会进入wait,适合长时间持有的锁情况
  5. 读-写信号量-downread upread downwrite upwrite(多个写,可以分段写,比较少用)(分段锁)
  6. 互斥体(mutex)-特殊的信号量(二值信号量)
  7. 完成变量-特殊的信号量(A发出信号给B,B等待在完成变量上。vfork()在子进程结束时通过完成变量叫醒父进程 类似于(Latch)
  8. BKL:大内核锁(早期,现在已经不用)
  9. 顺序销(26) 一线程可以挂起的迹写自旋锁序列计数器(从0开始,写时增加(+1),写完释放(+1),读前发现单数,说明有写线程,等待,读前读后序列一样,说明没有写线程打断)
  10. 禁止抢占-preempt disable)
  11. 内存屏障-见volatile

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

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

相关文章

elementUI,自定义表头,多层级表头,表头合并,行内容一致的合并行

先上效果&#xff1a; 1.自定义表头&#xff1a; 通过设置 slot"header" 来自定义表头。 slot-scope"scope" 这一行千万不要因为没有再template中使用到scope&#xff0c;vscode报红而删除&#xff0c;这会导致input框不能输入任何内容&#xff01; &l…

软考网工计算题总结(一):总共27类题型,进来复习啦!

题型一&#xff1a; 1.地址编号从80000H到BFFFFH且按字节编址的内存容量为&#xff08;5&#xff09;KB,若用16KX4bit的存储芯片够成该内存&#xff0c;共需&#xff08;6&#xff09;片。 (5)A.128 B.256 C.512 D.1024 (6)A.8 B.16 C.32 D.64 【答案】B C 【解析】本题…

写一个自己的MyGPT app

chatGPT大火之后&#xff0c;国内外一众玩家撸起袖子热火朝天干了起来。 借助开源的GPT可以轻松的拥有自己的专属GPT&#xff0c;装装逼还是很好用的&#xff0c;也算赶一下chatGPT的风口。 这里使用ANYGPT&#xff0c;打造自已的GPT&#xff0c;AnyGPT API 开发者文档 语雀…

【STM32】基础知识 第十六课 窗口看门狗 WWDG 深入浅出

【STM32】基础知识 第十六课 窗口看门狗 WWDG 深入浅出 概述窗口看门狗 (WWDG)WWDG_SR 状态寄存器WWDG 配置与使用使用 WWDG 进行故障检测案例 概述 在嵌入式开发中, 可靠性和稳定性是至关重要的. 这就是为什么许多单片机, 比如 STM32, 提供了窗口看门狗 (Window Watchdog, WW…

redis 源码记录

正好最近时间富裕&#xff0c;看一看redis源码&#xff0c;简单的记录一下。也有可能说的是不全面的&#xff0c;自行斟酌&#xff0c;只能通过debug来简单的梳理本次测试流程&#xff0c;而不是全量的覆盖的所有测试用例&#xff0c;时不时更新&#xff0c;争取一天学一点点。…

基于Web的水果蔬菜销售系统的设计与实现(论文+源码)_kaic

摘 要 随着互联网经济与技术进程的不断推进&#xff0c;网上购物方式受到公众的普遍关注和欢迎。传统的樱桃线下销售模式缺陷不断暴露&#xff0c;难以满足公众不断加快的生活节奏和生活方式的需求。本文根据目前大众的实际需要&#xff0c;根据网上商城的特点、现状以及主要功…

Java 与排序算法(3):插入排序

一、插入排序 插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法&#xff0c;它的基本思想是将待排序序列分为已排序区间和未排序区间&#xff0c;然后每次从未排序区间取出一个元素&#xff0c;将其插入到已排序区间的合适位置中&#xff0c;使得插入…

【SpringBoot】八:Web服务---WebMvcConfigurer

文章目录 1.WebMvcConfigurer简介2. 页面跳转控制器3. 数据格式化4. 拦截器4.1 一个拦截器4.2 多个拦截器 1.WebMvcConfigurer简介 WebMvcConfigurer是SpringMVC xml配置文件的JavaConfig实现方式。 2. 页面跳转控制器 创建 SpringMVC 配置类: 3. 数据格式化 Formatter&…

计算机组成原理-存储系统-主存储器(芯片)和CPU连接

目录 一、SRAM和DRAM芯片 DRAM&#xff1a;栅极电容存储信息 SRAM&#xff1a;双稳态触发器存储信息 区别​编辑 二、ROM芯片 三、主存于CPU的连接 位扩展法 字扩展法 字位同时扩展法 译码器 四、双端口RAM和多模块存储器 4.1双端口RAM 4.2多模块存储器 4.2.1单体多字…

pthread多线程: 创建最简单的线程

文章目录 1. 目的1.1 不使用 Pthread 的情况1.2 使用 Pthread 的情况1.3 使用 Pthread 的好处 2. Pthread 创建线程的 API2.1 环境2.2 pthread_create()2.3pthread_join() 3. 创建最简单的线程3.1 要点3.2 代码 4. 创建多个子线程4.1 要点4.2 代码 5. 总结 1. 目的 Pthread 提…

计算机组成原理-存储系统-基本概论及组成

目录 一、存储器的层次化结构 二、存储器分类 存储介质 存取方式 信息可改性 三、性能指标 四、主存储器基本组成 基本的的半导体元件及原理 存储芯片的基本原理 一、存储器的层次化结构 二、存储器分类 存储介质 半导体存储器(主存&#xff0c;cache)、磁表面存储器(…

基于SpringBoot的SSMP的整合案例

基于SpringBoot的SSMP的整合案例 简单介绍模块创建创建实体类导入Mybatis-plus和druid的配置文件使用junit测试查询方法MP分页查询按照条件进行查询业务层Service开发业务层Service快速开发表现层开发表现层 实现分页查询表现层消息一致性的处理查询所有书本信息添加书本删除操…

TensorFlow巨浪中的巨人:大数据领域的引领者 TensorFlow实战【上进小菜猪大数据系列】

上进小菜猪&#xff0c;沈工大软件工程专业&#xff0c;爱好敲代码&#xff0c;持续输出干货。欢迎订阅本专栏&#xff01; 大数据时代的到来带来了海量数据的处理和分析需求。在这个背景下&#xff0c;TensorFlow作为一种强大的深度学习框架&#xff0c;展现了其在大数据领域…

fastreport使用教程(fastreport报表编辑器)

除了库本身&#xff0c;FastReport.Net还包括单独的程序 – Designer和Viewer。 如您所知&#xff0c;第一个用于创建和编辑报表模板。它具有报表预览模式&#xff0c;您可以从中查看报表&#xff0c;将其导出为所需的数据格式并将其发送到打印。 Viewer用于以fpx预览格式查看报…

清华p-tuning | GPT也能做NLU?清华推出p-tuning方法解决GPT系列模型fine-tuning效果比BERT差问题

一、概述 title&#xff1a;GPT Understands, Too 论文地址&#xff1a;https://arxiv.org/abs/2103.10385 代码&#xff1a;https://github.com/THUDM/P-tuning 1.1 Motivation GPTs模型利用传统的fine-tuning技术在NLU任务上效果比较差&#xff0c;比同等量级的BERT效果…

2023/5/22总结

继承 继承是面向对象三大特征之一。可以使得子类具有父类的属性和方法&#xff0c;还可以在子类中重新定义&#xff0c;追加属性和方法。 如图&#xff1a; 在上面的图片中&#xff0c;dog和cat都继承了Animal类&#xff0c;所以dog和cat都可以称为Animal的子类或者派生类&…

chatgpt赋能Python-python_dng

Python DNG&#xff1a;开启更高效的数据处理之路 什么是Python DNG&#xff1f; Python DNG&#xff08;Data NumPy Generator&#xff09;是一种基于Python的高效数据生成器&#xff0c;可以加速数据处理和分析的过程。它基于Numpy数组操作和并行计算思想&#xff0c;可以快…

C++详解NOI题:[NOIP2021] 报数

文章目录 前言一、题目二、暴力解题步骤&#xff08;50分&#xff09;三、打表防坑解题&#xff08;100分&#xff09;总结 前言 受不了CSDN每日一练的在线竞赛系统了&#xff0c;bug多就算了&#xff0c;勉强能用&#xff0c;可那些题目的神描述&#xff0c;到处是错。所以找…

前端面试知识点总结

前言&#xff1a; 博主突击两个月八股拿到美团&#xff08;基础研发&#xff09;&#xff0c;腾讯&#xff08;IEG&#xff09;&#xff0c;百度&#xff08;搜索部门&#xff09;暑期实习offer call&#xff0c;这是我学习过程中整理的前端知识点&#xff0c;内容有些多&#…

【13900k】i9 核显升级驱动

这里写自定义目录标题 官方的助手不能用显卡控制中心提示最新的更新搜索显卡 intel uhd graphics 770 手动下载安装自定义音频为啥也要卸载&#xff1f;新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片…