[学习笔记]《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

相关文章

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

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.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于