ARM内核的CPU架构模型

1.引言

程序员在编码的时候,如果想有进一步的提升,我认为还是要深入底层理解程序运行原理才好。最近看了一些ARM架构的讲解,总结了如下。虽然是以ARM为原型画的图形,但是对于C和C++的编程,还是有一些参考价值的。

2. ARM内核架构(硬件层面)

3.简述以上图形

程序运行起来时,会把编译后的机器码程序从flash(或硬盘中)中加载到RAM中。CPU内核中的PC寄存器指向的机器码地址,就会运行这些指令,就是汇编里常常提到的MOV,ADD,LDR等命令。这些指令的执行会使通用寄存器(R0~R15)和内存RAM产生交互。ARM的CPU处理器有7中运行模式,我们熟悉的是用户模式,其他6种模式是异常模式,每一种模式下都分别对应有自己的一套通用寄存器,当然有一些寄存器在所用模式下都是共通的。加上CPU状态寄存器,7中运行模式对应有37个通用寄存器。

  • 程序运行时,从数据交互上就是使用通用寄存器和RAM交互的过程。
  • 程序运行时随着函数调用,RAM中会有动态变化的栈产生,也有数据堆产生,数据堆中的数据资源一般在程序中会有指针指向,便于操作数据资源。
  • 内存RAM中一些高频访问的资源,为了提升访问效率,在CPU内核中会部署一些数据缓存区,分为L1,L2和L3。
相关推荐
大胆飞猪1 小时前
C++9--前置++和后置++重载,const,日期类的实现(对前几篇知识点的应用)
c++
1 9 J1 小时前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
夕泠爱吃糖1 小时前
C++中如何实现序列化和反序列化?
服务器·数据库·c++
长潇若雪1 小时前
《类和对象:基础原理全解析(上篇)》
开发语言·c++·经验分享·类和对象
仍然探索未知中2 小时前
C语言经典100例
c语言
爱吃西瓜的小菜鸡2 小时前
【C语言】矩阵乘法
c语言·学习·算法
染指11103 小时前
50.第二阶段x86游戏实战2-lua获取本地寻路,跨地图寻路和获取当前地图id
c++·windows·lua·游戏安全·反游戏外挂·游戏逆向·luastudio
Code out the future3 小时前
【C++——临时对象,const T&】
开发语言·c++
Stark、3 小时前
【Linux】文件IO--fcntl/lseek/阻塞与非阻塞/文件偏移
linux·运维·服务器·c语言·后端
sam-zy4 小时前
MFC用List Control 和Picture控件实现界面切换效果
c++·mfc