计算机底层知识

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

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

计算机通电->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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

安卓开发 | 将Vue项目打包为app

知识目录 一、写在前面✨二、Hbuilder X准备&#x1f495;2.1 Hbuilder X简介2.2 下载 三、打包&#x1f495;3.1 获取dist目录3.2 新建5app3.3 替换文件3.4 编写manifast.json文件3.5 app云打包 四、总结撒花&#x1f60a; 一、写在前面✨ 大家好&#xff01;我是初心&#xf…

OJ练习第107题——二叉搜索子树的最大键值和

二叉搜索子树的最大键值和 力扣链接&#xff1a;1373. 二叉搜索子树的最大键值和 题目描述 给你一棵以 root 为根的 二叉树 &#xff0c;请你返回 任意 二叉搜索子树的最大键值和。 二叉搜索树的定义如下&#xff1a; 任意节点的左子树中的键值都 小于 此节点的键值。 任意…

龙蜥白皮书精选:利用 io_uring 提升数据库系统性能

文/高性能存储 SIG 01 背景介绍 传统的 IO 软件栈已经无法完全释放出高性能存储设备的性能&#xff0c;高性能 IO 栈是当前存储领域重点研究的课题之一&#xff0c;代表性的如用户态方案 SPDK&#xff0c;以及标准的内核态方案 io_uring。 02 关键技术 Linux 社区从零开始设…

SeaweedFs使用-通过http接口实现文件操作

通过http接口实现文件操作 SeaweedFs可通过filer的http接口/master中的http接口来进行文件上传 1.通过master的接口进行上传文件 通过各种方式进行请求接口&#xff1a;http://localhost:9333/submit, ip和端口号是master服务的信息。此接口通过post请求方式将文件的二进制流…

esp32CAM环境安装教程---串口驱动安装

前言 &#xff08;1&#xff09;本人安装好arduino 的ESP32环境之后&#xff0c; 发现一直下载不进去程序。一直说Cannot configure port, something went wrong. Original message: PermissionError。 &#xff08;2&#xff09;查阅了很多资料&#xff0c;用了各种办法&#…

自动生成测试用例_接口测试用例自动生成工具

前言 写用例之前&#xff0c;我们应该熟悉API的详细信息。建议使用抓包工具Charles或AnyProxy进行抓包。 har2case 我们先来了解一下另一个项目har2case 他的工作原理就是将当前主流的抓包工具和浏览器都支持将抓取得到的数据包导出为标准通用的 HAR 格式&#xff08;HTTP A…

图片模块封装:Glide高级使用+使用设计模式图片框架封装+Bitmap尺寸压缩和质量压缩+Bitmap加载大图长图

图片模块封装&#xff1a;Glide高级使用使用设计模式图片封装Bitmap尺寸压缩和质量压缩Bitmap加载大图长图 一.如何更换图片框架二.策略模式构建者模式图片框架搭建1.ImageOptions图片参数设置2.IImageLoader接口以及实现子类3.图片加载策略4.ImageLoaderManager6.业务模块中使…

tcp/ip

这里写自定义目录标题 线程 防止阻塞 123 windows下4 https://zhuanlan.zhihu.com/p/139454200 https://www.bilibili.com/video/BV1eg411G7pW/?spm_id_from333.337.search-card.all.click&vd_sourcee7d12c9f66ab8294c87125a95510dac9 with socket.socket() as s:s.bind(…

小航编程题库2022年NOC决赛图形化(小高组)(含题库教师学生账号)

需要在线模拟训练的题库账号请点击 小航助学编程在线模拟试卷系统&#xff08;含题库答题软件账号&#xff09;_程序猿下山的博客-CSDN博客 单选题3.0分 删除编辑 答案:A 第1题运行下面的程序&#xff0c;最终“我的变量”的值是多少&#xff1f; A、5B、10C、25D、30 答案…

计及N-k安全约束的含光热电站电力系统优化调度模型【IEEE14节点、118节点】(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

南京邮电大学算法与设计实验三:动态规划法(最全最新,与题目要求一致)

实验原理&#xff1a; 1、用动态规划法和备忘录方法实现求两序列的最长公共子序列问题。要求掌握动态规划法思想在实际中的应用&#xff0c;分析最长公共子序列的问题特征&#xff0c;选择算法策略并设计具体算法&#xff0c;编程实现两输入序列的比较&#xff0c;并输出它们的…

编译原理之词法分析实验(附完整C/C++代码与总结)

一、实验内容 通过完成词法分析程序&#xff0c;了解词法分析的过程。编制一个读单词程序&#xff0c;对PL/0语言进行词法分析&#xff0c;把输入的字符串形式的源程序分割成一个个单词符号&#xff0c;即基本保留字、标识符、常数、运算符、分界符五大类。 对PL/0语言进行词法…

【野火启明_瑞萨RA6M5】按键输入检测

文章目录 一、GPIO输入——按键输入检测二、硬件设计三、软件设计下载验证 一、GPIO输入——按键输入检测 按键检测原理 按键机械触点断开、闭合时&#xff0c;由于触点的弹性作用&#xff0c;按键开关不会马上稳定接通或一下子断开&#xff0c;使用按键时会产生 下图中的带波…

APlayer MetingJS 音乐播放器使用指南

文章目录 1.引用2.安装3.APlayer 原生用法4.MetingJS 的用法 1.引用 APlayer 是一个简洁漂亮、功能强大的 Html5 音乐播放器&#xff0c;GitHub地址&#xff1a;https://github.com/DIYgod/APlayer MetingJS 是为 APlayer 添加网易云、QQ音乐等支持的插件&#xff0c;GitHub地…

MySQL 用户管理

目录 用户管理 用户 用户信息 创建用户 删除用户 修改用户密码 数据库的权限 给用户 注意&#xff1a;如果发现赋权限后&#xff0c;没有生效&#xff0c;执行如下指令&#xff1a; 回收权限 用户管理 如果我们只能使用 root 用户&#xff0c;这样存在安全隐患。这时…

用streamlit,几行代码就可以拥有漂亮图表!

大家注意&#xff1a;因为微信最近又改了推送机制&#xff0c;经常有小伙伴说错过了之前被删的文章&#xff0c;比如前阵子冒着风险写的爬虫&#xff0c;再比如一些限时福利&#xff0c;错过了就是错过了。 所以建议大家加个星标&#xff0c;就能第一时间收到推送。&#x1f44…

QTableWidget样式设置

QTableWidget的样式分为几个部分&#xff1a; 分别是&#xff1a; 外框&#xff1a;QTableWidget 表头&#xff1a;QHeaderView 表头字段&#xff1a;QHeaderView::section 表格&#xff1a;QTableWidget::item 选中的表格&#xff1a;QTableWidget::item::selected 水平滚动条…

JDBC详解(六):数据库事务(超详解)

JDBC详解&#xff08;六&#xff09;&#xff1a;数据库事务&#xff08;超详解&#xff09; 前言一、数据库事务介绍二、JDBC事务处理三、事务的ACID属性1、数据库的并发问题2、四种隔离级别3、在MySql中设置隔离级别 前言 本博主将用CSDN记录软件开发求学之路上亲身所得与所…

海康威视 2024届 数字逻辑设计 实习笔试分析

说明 记录一下 5月11日晚&#xff0c;做的海康威视的一场笔试。分享给需要的IC人。 岗位&#xff1a;数字逻辑设计工程师&#xff08;浙江 杭州&#xff09; 转载需要本人同意&#xff01; 我的见解不一定都是准确的&#xff0c;欢迎评论区交流指正~~ 单选题 1、&#xff…

一分钟带你了解网络安全(如何自学)

一、关于网络安全职业 早些年&#xff0c;网络安全刚起步&#xff0c;作为一个网络安全从业人员&#xff0c;最苦恼的事情就是每当回到村里变成狗蛋儿的时候&#xff0c;七大姑八大姨&#xff0c;邻里乡亲&#xff0c;村子里的各种人都会来找你&#xff0c;狗蛋儿&#xff0c;你…