[学习笔记]《CSAPP》深入理解计算机系统 - Chapter 3 程序的机器级表示

本文主要是介绍[学习笔记]《CSAPP》深入理解计算机系统 - Chapter 3 程序的机器级表示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总结一些第三章的一些关键信息

  • Chapter 3 程序的机器级表示
    • 结构
  • updating...

Chapter 3 程序的机器级表示

  1. 局部变量通常保存在寄存器中,而不是内存中,访问寄存器比内存快的多.
    有些时候,局部数据必须存放在内存中,
    • 寄存器不足够存放所有的本地数据
    • 对一个局部变量使用地址运算符 &, 因此必须能够为它产生一个地址
    • 某些局部变量是数组或结构,因此必须能够通过数组或结构引用被访问到。
  2. C 语言中所谓的“指针”其实就是地址。
  3. x86-32 中,程序栈存放在内存中的某个区域,栈向下增长。(栈顶在低地址处)
  4. switch 使用跳转表(jump table)来实现的。(一般在开关情况多,比如4个以上时,会用跳转表)
  5. 寄存器是唯一被所有过程共享的资源,过程可以理解成函数调用…根据惯例,%rbx、%rbp%r12~%~15被划分为“被调用者”保存的寄存器。当过程P调用过程Q时,Q必须保存这些寄存器的值,保证他们的值在Q返回到P时,与Q被调用时是一样的
    • Q: 多次调用怎么办? A:P 把之前的值保存在栈上

结构

结构的所有组成部分都存放在内存中一段连续的区域内,而指向结构的指针就是结构第一个字节的地址。编译器维护关于每个结构类型的信息,指示每个字段(filed)
的字节偏移。它以这些偏移作为内存引用指令中的位移,从而产生对结构元素的引用。

动态确定和静态编译确定的简要理解:

  • 如果是数组 a[10], 这个就是静态编译确定的,并且保存在栈帧中。而如果是a[n], 然后根据传入的n的数值通过 malloc等方式申请内存,就是动态的,并且保存在堆中, 由指针保存对应内存的地址。
  • 代码段:保存可执行文件中的机器指令
  • 数据段:保存全局变量和静态变量
  • 堆: 动态内存分配保存,比如 malloc
  • 栈: 用于存储局部变量和函数调用的上下文信息。
在计算机科学中,上下文信息(Context)指的是在某个特定时刻,程序执行所需的全部状态信息。对于函数调用而言,上下文信息包括了所有必要的数据,使得函数调用能够正确执行,并在执行完毕后能够恢复到调用前的状态。具体来说,函数调用的上下文信息通常包括:参数传递:函数所需的参数值,这些参数可能通过寄存器或栈来传递。返回地址:当函数执行完毕后,需要返回到调用者的位置,返回地址就是调用者在函数调用后的下一条指令的地址。局部变量:函数内部声明的局部变量的存储空间。寄存器保存:在函数调用前后,需要保存和恢复某些寄存器的值,以保证函数调用不会影响调用者的环境。栈帧指针:在多层函数调用的情况下,每个函数都有自己的栈帧,栈帧指针(如基指针 rbp 或帧指针 ebp 在 x86 架构中)用于指向当前函数的栈帧,以便能够访问局部变量和其他上下文信息。程序状态:包括程序计数器(PC)和其他状态寄存器,如程序状态字(PSW)或标志寄存器(FLAGS),它们记录了程序的执行状态。在函数调用时,调用者会将这些上下文信息保存到栈中,通常是通过一系列的 push 指令来完成。被调用的函数在执行前,会创建自己的栈帧,这通常涉及到将当前的栈指针(如 rsp 或 esp)移动到新的栈帧位置。函数执行完毕后,会通过 pop 指令或 ret 指令来恢复调用者的上下文信息,包括返回地址和寄存器状态,然后继续执行调用者的代码。上下文切换(Context Switching)是操作系统在多任务环境中,从一个任务切换到另一个任务的过程,这个过程也需要保存和恢复任务的上下文信息。

updating…

这篇关于[学习笔记]《CSAPP》深入理解计算机系统 - Chapter 3 程序的机器级表示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139379

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言