计算机系统基础

news2024/11/15 12:54:51

C 语言相关内容省略,复习自用,仅供参考~

概述

冯·诺伊曼结构

存储程序工作方式:将事先编好的程序和原始数据送入主存后才能执行程序,程序被启动执行后,计算机能在不需要操作人员干预下自动完成逐条指令取出和执行的任务。
模型机的基本硬件结构
程序执行过程:主存取指令 → \to 指令译码 → \to PC 自增 → \to 取操作数并执行 → \to 结果送往主存或寄存器

层次结构

计算机系统抽象层次转换
计算机系统的层次化结构

性能评价

单位时间完成的工作量:吞吐率,带宽;作业提交开始到完成所需的时间:响应时间,执行时间,等待时间或时延。

用户 CPU 时间 = = = 平均时钟周期数 × \times × 时钟周期 = = = 平均指令条数 × \times × CPI × \times × 时钟周期.
时钟周期(ns) = 1 / =1/ =1/ 时钟频率(GHz); 1 1 1 GHz = 1 0 3 10^3 103 MHz = 1 0 9 = 10^9 =109 Hz; 1 1 1 s = 1 0 9 10^9 109 ns.
CPI(执行一条指令所用的时钟周期) = = = 平均时钟周期数 ÷ \div ÷ 平均指令条数.
MIPS(平均每秒执行百万条指令数) = 1 / =1/ =1/ 时钟周期(ns) ÷ \div ÷ CPI × 1 0 − 6 \times 10^{-6} ×106.

CPI 越低,时钟频率越高(即时钟周期越低)时,用户 CPU 时间越低(即CPU执行速度越快)。
峰值 MIPS 在 CPI 最低处。

整体改进后速度提升倍数 = 1 / ( =1/( =1/( 改进部分时间比例 / / / 改进部分速度提升倍数 + + + 未改进部分时间比例 ) ) ).

数据

整数

进制转换 b n . . . b 0 . b − 1 . . . b − m ( R ) = ∑ i = − m n b n R n ( 10 ) , m , n > 0 {b_n...b_0.b_{-1}...b_{-m}}_{(R)}={\sum_{i=-m}^n b_nR^n}_{(10)}, m,n>0 bn...b0.b1...bm(R)=i=mnbnRn(10),m,n>0.
2 进制 ⇔ \Leftrightarrow 16 进制:4 位一组。
小端存储 A 1 A 2   ∣   B 1 B 2   ∣   C 1 C 2   ∣   D 1 D 2 → D 1 D 2 C 1 C 2 B 1 B 2 A 1 A 2 ( 16 ) A_1A_2\ | \ B_1B_2\ | \ C_1C_2\ | \ D_1D_2 \to {D_1D_2C_1C_2B_1B_2A_1A_2}_{(16)} A1A2  B1B2  C1C2  D1D2D1D2C1C2B1B2A1A2(16).
字长:ALU 内部的数据宽度。
补码:正数符号位为 0,数值为自身;负数符号位为1,数值为按位取反后末位加 1。
求反: − y = ( ∼ y ) + 1 -y=(\sim y)+1 y=(y)+1,其中 ∼ \sim 为按位取反。

加法器标志寄存器ZF 零标志OF 溢出标志SF 符号标志CF 进/错位标志
0结果不为 0结果未溢出(有符号)结果为正结果最高位发生进/错位;结果未溢出(无符号)
1结果为 0结果发生溢出(有符号)结果为负结果最高位无进/错位;结果发生溢出(无符号)

减法时, x − y = x + ( ( ∼ y ) + 1 ) x-y=x+((\sim y)+1) xy=x+((y)+1) 中加法进位记为 C C C,则 C F = ! C CF=! C CF=!C,其中 ! ! ! 为逻辑非。

异号相加同号相减时,永远不会溢出。
正溢出:正数 + + + 正数 → \to 负数,即正数 − - 负数 → \to 负数。
负溢出:负数 + + + 负数 → \to 正数,即负数 − - 正数 → \to 正数。

浮点数(IEEE 754)

单精度值类型符号(1位)阶码(8位,偏置127)尾数(23位)
规格化非零数0 或 1 0 < e < 255 0<e<255 0<e<255任意 ( − 1 ) s × 2 e − 127 × ( 1. f ) (-1)^s\times2^{e-127}\times(1.f) (1)s×2e127×(1.f)
正零000 + 0 +0 +0
负零100 − 0 -0 0
正无穷大0全 1,即 255 ( 10 ) _{(10)} (10)0 + ∞ +\infty +
负无穷大1全 10 − ∞ -\infty
非规划化数0 或 10非 0下溢, ( − 1 ) s × 2 − 126 × ( 0. f ) (-1)^s\times2^{-126}\times(0.f) (1)s×2126×(0.f)
非数0 或 1全 1非 0 N a N NaN NaN
  • 浮点数加减法
    对阶:小阶向大阶对齐,隐藏位还原到尾数。
    尾数加减:定点原码加减,注意符号
    规格化:右规,尾数右移,阶码加 1;左规,尾数左移,阶码逐次减 1。
    尾数舍入:保护位 + + + 舍入位 + + + 粘位;就近舍入(0 舍 1 入),正向舍入,负向舍入,向 0 舍入。
    溢出判断:右规时会发生阶码上溢;左规时会变为非规格化数。

汇编(IA-32)

基础

  • AT&T 格式
    指令形式:“op src,dst”,即 dst ← \gets dst op src.
    长度后缀:b → \to 8bit;w → \to 16bit;l → \to 32bit;q → \to 64bit.
    数字:“$number”.
    寄存器操作数:“%register”.
    存储器操作数(寻址方式):“offset ( %base, %index, scale )”,即 %base + + + %index × \times × scale + + + offset.
    指令类型:传送(数据传送/地址传送/标志传送/IO);定点算术运算(加减乘除/自增自减/取负/比较);按位运算(逻辑/移位);控制转移(无条件转移/条件转移/条件设置/条件传送/调用返回/内中断)。
  • IA-32 寄存器
    通用寄存器(32bit):EAX 累加器,EBX 基址寄存器,ECX 计数寄存器,EDX 数据寄存器,ESP 栈指针寄存器,EBP 基址指针寄存器,ESI 源变址寄存器,EDI 目标变址寄存器。
    专用寄存器(32bit):EIP 指针指令寄存器,EFLAGS 标志寄存器。
    段寄存器(16bit):CS 代码段,SS 堆栈段,DS 数据段,ES FS GS 附加段。

C语言逆向

(待更新~)
过程调用:内存分配,栈帧结构
运算还原
选择结构:switch-case实现 - 连续比较/数组/二分查找
循环结构:while/do-while/自增自减
数组
内存对齐

链接

ELF 文件格式:ELF 头 + + + .text 节(目标代码) + + + .rodata 节(只读数据) + + + .data 节(已初始化全局变量) + + + .bss 节(未初始化全局变量,占位符) + + + .symtab 符号表(函数名和非局部变量名) + + +.rel.text 节(重定位) + + + .rel.data 节(重定位) + + + .debug 节(调试符号表) + + + .line 节(-g 选项) + + + .strtab 节(符号及节名) + + + 节头表。
可读写数据段.data 节(已初始化全局变量) + + + .bss 节(未初始化全局变量,占位符)

符号分类:全局非 static);外部extern);本地static)。
符号解析:强符号为函数名和已初始化全局变量名;弱符号为未初始化全局变量名;本地符号无强弱。
强符号只能定义一次;同时有强弱符号,符号类型以强符号为准弱符号指向同一处地址;多个弱符号,任选其一。

例题

  • 有符号整数表示(字长 16bit)
    0F 80 → \to 1000 0000 0000 1111 (补) → \to -32753 ( 10 ) _{(10)} (10).
  • 有符号整数减法(字长 8bit)
    A3H - 3AH → \to 1010 0011 (补) − - 0011 1010 (补) = = = 1010 0011 (补) + 1100 0110 (补) = = = 0110 1001 (补) → \to 69H; 标志 CF = = = 0, OF = 1 =1 =1, SF = = = 0, ZF = = = 0; 负溢.
  • 单精度浮点数表示(大端)
    3FB00000H → \to 1.011B → \to 1.375 ( 10 ) _{(10)} (10).
    C2FA4000H → − \to - 1.111101001B → \to -125.125 ( 10 ) _{(10)} (10).
  • 单精度浮点数加法(大端)
    3FB00000H + + + C2FA4000H → \to 对阶 0.00000101100 ( 2 ) +   − _{(2)} +\ - (2)+  1.111101001 ( 2 ) _{(2)} (2); 阶码 10000101 ( 2 ) → _{(2)} \to (2) 尾数加减 − - 1.11101111000 ( 2 ) → _{(2)}\to (2) 规格化 1 ∣ | 1000 0101 ∣ | 1110 1111 0000 0000 0000 000 → \to 尾数舍入(无) → \to C2F78000H.
  • 链接(gcc -m32)
// main.c
#include <stdio.h>
int d = 100;
int x = 200;
int y = 300;
void pi(void);

int main() {
  y = 0;
  p1();
  printf("d=%d, x=%d, y=%d\n", d, x, y);
  return 0;
}
// p1.c
double d;
short y;
void p1(void) {
  d = 1.0;
  y = -100;
}
gcc -m32 -o linktest main.c p1.c
./linktest
>>> d=0, x=1072693248, y = 65436

d = d= d= 1.0 (double, 64 bit) → \to 00 00 00 00 ∣ | 00 00 F0 3F (小端) → x = \to x= x= 3FF00000H (大端), d = d= d= 0 → x = \to x= x= 1072693248, d = d= d= 0.
y = y= y= -100 (short, 16bit) → \to 1001 1100 1111 1111 (补) → \to 11 11 11 11 11 11 11 00 11 01 10 ∣ | 00 00 … (小端) → \to 65436 ( 10 ) _{(10)} (10).

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

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

相关文章

【电商项目实战】实现订单超时支付取消

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《电商项目实战》。&#x1f3af;&#x1f3af; &am…

OpenHarmony源码转换器—多线程特性转换

本文讨论了如何将多线程的 Java 代码转换为 OpenHarmony ArkTS 代码​ 一、简介 Java 内存共享模型 以下示例伪代码和示意图展示了如何使用内存共享模型解决生产者消费者问题。 生产者消费者与共享内存间交互示意图 为了避免不同生产者或消费者同时访问一块共享内存的容器时…

阶段十-分布式-Redis02

第一章 Redis 事务 1.1 节 数据库事务复习 数据库事务的四大特性 A&#xff1a;Atomic &#xff0c;原子性&#xff0c;将所以SQL作为原子工作单元执行&#xff0c;要么全部执行&#xff0c;要么全部不执行&#xff1b;C&#xff1a;Consistent&#xff0c;一致性&#xff0…

Vue前端文字效果:如何让一段文本像是手动一个一个字打出来的

效果展示 自己做的AI聊天机器人界面&#xff0c;我觉得比微信还好看 由于这个前端略微复杂&#xff0c;下文用最简单的例子来展示&#xff1a; 分析需求 对于AI聊天工具的前端&#xff0c;如果AI生成的文本像是一个一个字打出来的&#xff0c;就会让AI看起来更像真的人&…

详解卡尔曼滤波(Kalman Filter)

1. 从维纳滤波到卡尔曼滤波 黑盒&#xff08;Black Box&#xff09;思想最早由维纳&#xff08;Wiener&#xff09;在1939年提出&#xff0c;即假定我们对从数据到估计中间的映射过程一无所知&#xff0c;仅仅用线性估计&#xff08;我们知道在高斯背景下&#xff0c;线性估计…

STM32 HAL库定时器触发DMA并口数据传输

代码目的&#xff1a; STM32与FPGA通讯&#xff0c;通过8位并口线进行通讯&#xff0c;16byte的数据在10us之内通过8位并口数据线传给FPGA&#xff0c;FPGA读取该数据。 HAL库设置说明&#xff1a; 时钟采用80MHz&#xff0c;由于16byte的数据要在10us之内传完&#xff0c;那…

[笔记] 使用 qemu 创建虚拟磁盘并安装 grub

之前使用 wsl 进行了直接创建虚拟磁盘并安装 grub,现在希望能够直接借助 qemu 的工具创建虚拟磁盘文件并安装 grub,由于需要用到 nbd(net block device网络块设备) 模块,在 wsl 中并不支持,因此这里使用到了 Hypver-V 虚拟机创建了一个 Ubuntu 系统,在系统中安装了 qemu 和 gru…

物联网安全:保护关键网络免受数字攻击

物联网 (IoT) 彻底改变了当今互联世界中的各个行业&#xff0c;实现了智能家居、自动驾驶汽车和先进的工业系统。然而&#xff0c;随着物联网设备数量的急剧增加&#xff0c;这些设备和相应网络的安全性已成为人们关注的焦点。本文旨在探讨物联网安全的重要性&#xff0c;同时简…

Pandas教程(五)—— 数据重塑透视及批量处理

1.数据重塑 重塑数据主要有两种方式&#xff0c;分别是 stack&#xff08;堆叠&#xff09;和 unstack&#xff08;拆堆&#xff09;&#xff0c;他们两个是互逆的操作 函数作用 data.stack&#xff08; &#xff09; 堆叠 会“旋转”或将列中的数据透视到行 列 一一> 行…

AWS(三):如何在AwsManagedAd目录和windowsAD实例之间建立双向信任。

前提&#xff1a; 1.创建好了一个AWS managed AD目录&#xff0c;我的目录域名为:aws.managed.com 2.创建好了一个windows AD实例并提升了为域控服务器,实例域名为:aws2.com 看过我AWS 一和二的应该都会创建windows实例了&#xff0c;切记不能将其无缝加入到aws managed AD的…

(JAVA)-反射

什么是反射&#xff1f; 反射允许对成员变量&#xff0c;成员方法和构造方法的信息进行编程访问。 说简单点就是反射能将类里面的构造方法&#xff0c;成员变量,修饰符,返回值&#xff0c;注解&#xff0c;类型&#xff0c;甚至异常等类里面的所有东西都能够获取出来。 关于C…

打造炫酷粒子效果的前端利器tsParticles

前端潮流速递 &#xff1a;打造炫酷粒子效果的前端利器tsParticles 在现代前端开发中&#xff0c;动画和视觉效果是吸引用户的关键元素之一。而实现炫酷而引人入胜的粒子效果&#xff0c;常常需要耗费大量的时间和精力。然而&#xff0c;有了 tsParticles&#xff0c;这一切变…

GitHub上的15000个Go模块存储库易受劫持攻击

内容概要&#xff1a; 目前研究发现&#xff0c;GitHub上超过15000个Go模块存储库容易受到一种名为“重新劫持”的攻击。 由于GitHub用户名的更改会造成9000多个存储库容易被重新劫持&#xff0c;同时因为帐户删除&#xff0c;会对6000多个存储库造成重新劫持的危机。目前统计…

【MySQL·8.0·源码】MySQL 表的扫描方式

前言 在进一步介绍 MySQL 优化器时&#xff0c;先来了解一下 MySQL 单表都有哪些扫描方式。 单表扫描方法是基表的读取基础&#xff0c;也是完成表连接的基础&#xff0c;熟悉了基表的基本扫描方式&#xff0c; 即可以倒推理解 MySQL 优化器层的诸多考量。 基表&#xff0c;即…

半导体行业-SECS/GEM协议 JAVA与SECS/GEM通信 什么是配方?springboot集成SECS通信协议 配方管理S7FX

Java与SECS基础通信 Java实现SECS指令S2F17获取时间 Java实现SECS指令 S10F3 终端单个显示例子 Java实现SECS指令 S7FX配方管理 Java实现SECS指令 S5F1报警/取消报警上传 实例源码及DEMO请查阅 JAVA开发SECS快速入门资料&#xff0c;SECS S7F19 什么是半导体配方&…

Unity3D UGUI图集打包与动态使用(TexturePacker)

制作图集的好处&#xff1a; 众所周知CPU是用来处理游戏的逻辑运算的&#xff0c;而GPU是用来处理游戏中图像的。在GPU中&#xff0c;我们要绘制一个图像需要提交图片&#xff08;纹理&#xff09;到显存&#xff0c;然后再进行绘制&#xff08;在这个过程中会产生一次DrawCall…

书生-浦路大模型全链路开源体系

2023年&#xff0c;大模型成为热门关键词 论文链接 大模型已经成为发展通用人工智能的重要途经 模型评测过程&#xff1a;从模型到应用 全链条开源开发体系 | 数据&#xff1a; 多模态融合 万卷包含文本、图像和视频等多模态数据&#xff0c;涵盖科技、文学、媒体、教育和法…

力扣hot100 二叉树的层序遍历 BFS 队列

&#x1f468;‍&#x1f3eb; 题目地址 时间复杂度&#xff1a; O ( n ) O(n) O(n)空间复杂度&#xff1a; O ( n ) O(n) O(n) &#x1f60b; 队列写法 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode…

Pycharm恢复默认设置

window 系统 找到下方目录-->删除. 再重新打开Pycharm C:\Users\Administrator\.PyCharm2023.3 你的不一定和我名称一样 只要是.PyCharm*因为版本不同后缀可能不一样 mac 系统 请根据需要删除下方目录 # Configuration rm -rf ~/Library/Preferences/PyCharm* # Caches …

vue的小入门

vue的快速上手 Vue概念 是一个用于构建用户界面的渐进式框架优点&#xff1a;大大提高开发效率缺点&#xff1a;需要理解记忆规则 创建Vue实例 步骤&#xff1a; 准备容器引包创建Vue实例new Vue()指定配置项el data>渲染数据 el指定挂载点&#xff0c;选择器指定控制…