返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >详解C语言在STM32中的内存分配问题
  • 895
分享到

详解C语言在STM32中的内存分配问题

2024-04-02 19:04:59 895人浏览 独家记忆
摘要

01、前言 不说废话,先上示例代码 uint8_t num_byte[4]; uint32_t num_Word; const uint32_t num_word_const =

01、前言

不说废话,先上示例代码


uint8_t num_byte[4];
uint32_t num_Word;
const uint32_t num_word_const = 0x1234;
uint32_t *point_heap;
int main(void)
{
  uint8_t num_byte_stack;
  static uint8_t num_byte_static;
  
  point_heap = (uint32_t *)malloc(4);
  *point_heap = 0x3421;
  free(point_heap);
  
  num_byte_stack = 0x11;
  
#pragma section = "CSTACK"
  char *pbeginstk = __section_begin("CSTACK");
#pragma section = "HEAP"
  char *pbeginheap = __section_begin("HEAP");    
  
  printf("CSTACK addr is 0x%x\r\n",pbeginstk);
  printf("HEAP addr is 0x%x\r\n",pbeginheap);
  
  printf("num_byte addr is 0x%x\r\n",&num_byte);
  printf("num_word addr is 0x%x\r\n",&num_word);
  printf("num_word_const addr is 0x%x\r\n",&num_word_const);
  printf("point_heap addr is 0x%x\r\n",&point_heap);
  printf("point_heap is 0x%x\r\n",point_heap);
  printf("num_byte_stack addr is 0x%x\r\n",&num_byte_stack);
  printf("num_byte_static addr is 0x%x\r\n",&num_byte_static);
}

打印如下

STACK addr is 0x20000320
HEAP addr is 0x20000720
num_byte addr is 0x20000308
num_word addr is 0x2000030c
num_word_const addr is 0x8002a44
point_heap addr is 0x20000310
point_heap is 0x20000728
num_byte_stack addr is 0x200006f8

num_byte_static addr is 0x20000318

先说结论:

num_byte、num_word、num_byte_static和point_heap存储在内部RAM中。

num_byte_stack存贮在栈中。

point_heap申请到的内存在堆中。

num_word_const在内部flash中。

如果是有同学对这个了然于胸,可以出门左转了,如果有些同学有兴趣,可以进一步往下看。

02、大小端

因为后面的内容涉及到大小端问题,这里先说下大小端问题。

大端(Big-endian):数据的高位字节存放在地址的低端低位字节存放在地址高端;

小端(Little-endian):数据的高位字节存放在地址的高端低位字节存放在地址低端;

例如:

数据0x12345678存储格式

大端格式

低地址<----0x12|0x34|0x56|0x78---->高地址

小端格式

低地址<----0x78|0x56|0x34|0x12---->高地址

其中的地址,一般由编译器分配,也可在程序中自行指定。从上表中,可以清晰的看到,大小端是以字节为单位进行数据储存的方式。大端通俗的理解就是赋值数从左自右;小端则是从右自左。

我们常用的X86结构是小端模式,而KEILC51则为大端模式。很多的ARM,DSP都为小端模式,本文使用的平台STM32F207就是小段模式。

03、逐步分析

如果有同学对这部分不是很熟悉,建议先看一下我之前的推文《C语言的内存分配》,先把C语言的堆栈,内存等概念先熟悉下。

先说关于堆栈的问题,下面代码可以打印出IAR平台下STM32的堆栈起始位置。


#pragma section = "CSTACK"
  char *pbeginstk = __section_begin("CSTACK");
#pragma section = "HEAP"
  char *pbeginheap = __section_begin("HEAP");

打印的结果如下

STACK addr is 0x20000320

HEAP addr is 0x20000720

这个地址是否正确,我们可以在IARdebug时,使用Disassembly窗口查看。

关于堆栈大小问题,如下

可以查到栈的终止位置是0x20000720,堆的终止位置是0x20000920。注意:这里计算牵扯到大小端的问题。

通过计算:

栈的大小=0x20000720-0x20000320=0x400。

堆的大小=0x20000920-0x20000720=0x200。

这和我们在IAR中的堆栈配置是一样的。

接下来就先说一下分配在内存的变量。

通过打印看出,num_byte、num_word、num_byte_static和point_heap并不在堆栈中,它们存储在内部RAM中。

使用Disassembly窗口查看如下

这也验证了static关键字,在修饰函数内的局部变量时,这个变量将和全局变量一样存储在内部ram中。

同时也说明了,STM32内部分配内存时候,是先分配全局变量(和static修饰的局部变量),再分配栈,最后再分配堆的。

对于栈的内存分配,局部变量,也就是num_byte_stack是存储在栈的范围内。

num_byte_stack addr is 0x200006f8

它的地址空间在栈中。因为在代码中num_byte_stack =0x11;使用Disassembly窗口查看到对应的地址数值是0x11。

关于栈,再说一句,栈不仅仅保存了局部变量,它会在函数切换,中断发生时保存现场,保存ARM内核的寄存器,这些不是这篇文章的讨论重点,这里先挖个坑,等以后有空再写篇文章专门说说这个部分。

堆的问题,简单来说:malloc申请的内存都在堆中。point_heap指针指向的内存地址就在堆的范围内。

point_heap is 0x20000728

代码中*point_heap= 0x3421;在Disassembly窗口查看到对应的地址数值是0x3421。

最后一个num_word_const,const修饰的变量是存储在内部flash中的,它的地址在内部flash范围内。

在代码中也有对应的赋值操作,constuint32_t num_word_const = 0x1234;在Disassembly窗口查看到对应的地址数值是0x1234。

点击查看本文所在的专辑,STM32F207教程

到此这篇关于C语言在STM32中的内存分配的文章就介绍到这了,更多相关C语言内存分配内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详解C语言在STM32中的内存分配问题

本文链接: https://lsjlt.com/news/160701.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 详解C语言在STM32中的内存分配问题
    01、前言 不说废话,先上示例代码 uint8_t num_byte[4]; uint32_t num_word; const uint32_t num_word_const =...
    99+
    2024-04-02
  • 如何分析C语言在STM32中的内存分配问题
    今天就跟大家聊聊有关如何分析C语言在STM32中的内存分配问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。01、前言不说废话,先上示例代码uint8_t num_byte...
    99+
    2023-06-22
  • C程序中Ubuntu、stm32的内存分配问题
    目录一、内存分区概念介绍1.1、C/C++编译程序的内存占用1.2、栈和堆、全局/静态存储区和常量存储区的对比1.3、图片说明 二、C语言编程论证1.1、Ubuntu测试代码实现 1...
    99+
    2024-04-02
  • 如何解决C程序中Ubuntu、stm32的内存分配问题
    这篇文章主要介绍了如何解决C程序中Ubuntu、stm32的内存分配问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、内存分区概念介绍1.1、C/C++编译程序的内存占用...
    99+
    2023-06-22
  • C语言malloc分配问题详解
    目录前言一、malloc是什么?1.1malloc定义1.2malloc函数含义二、malloc的使用2.1添加头文件2.2malloc和free2.3malloc使用注意三、mal...
    99+
    2024-04-02
  • 详解C语言动态内存的分配
    目录C 程序中,不同数据在内存中分配说明内存动态分配的相关函数应用实例动态分配内存的基本原则总结C 程序中,不同数据在内存中分配说明 1)全局变量——内存中的...
    99+
    2024-04-02
  • C语言中关于动态内存分配的详解
    目录一、malloc 与free函数二、calloc三、realloc四、常见的动态内存的错误【C语言】动态内存分配 本期,我们将讲解malloc、calloc、realloc以及f...
    99+
    2024-04-02
  • C语言动态内存泄露常见问题内存分配改进方法详解
    目录一、例题二、2种改进方法法1:二级指针(传址调用)法2:返回指针总结一、例题 试问该段代码能打印什么,或者不能打印什么,说出理由 #define _CRT_SECURE_NO...
    99+
    2024-04-02
  • c++ class中成员与分配内存的问题详解
    目录1.内存补齐2.特殊情况--virtual函数3.不需要考虑的内存总结1.内存补齐 便于管理类(生成的对象)的内存,类总内存总是为最大成员字节大小的倍数,不足的会进行内存补齐 ...
    99+
    2024-04-02
  • C语言的动态内存分配及动态内存分配函数详解
    目录mallocmalloc的使用:freecalloccalloc的使用:reallocrealloc的使用改进:realloc的另一种用法:常见的动态内存错误对空指针的解引用操作...
    99+
    2024-04-02
  • C语言动态内存的分配实例详解
    目录前言动态内存分配的定义动态内存的优势<1>  可以控制内存的大小<2> 可以多次利用这部分空间<3>不占用栈区的内存malloc c...
    99+
    2024-04-02
  • C语言数据在内存中的存储详解
    目录文章摘要一、C语言的数据类型数据类型基本分为: 二、隐式类型转换1.什么是隐式类型转换2.整型提升 3.类型转换三、机器大小端1.什么是大小端2.大小端在截断的应用3....
    99+
    2024-04-02
  • 超详细分析C语言动态内存管理问题
    目录一、为什么存在动态内存的分配二、动态内存函数的介绍2.1 malloc和free2.2 calloc2.3 realloc三、常见的动态内存错误3.1 对NULL指针的解引用操作...
    99+
    2024-04-02
  • C语言详细分析浮点数在内存中的储存
    目录浮点数的储存格式初步了解深入探究E不全为0或不全为1E全为0E全为1浮点数的储存格式 初步了解 首先让我们通过一段代码来认识一下浮点型和整型的区别: int main() { ...
    99+
    2024-04-02
  • 深入了解C语言中的动态内存分配
    目录什么是动态内存分配如何进行动态内存分配首先我要介绍两个函数 malloc 和 free第二个开辟空间的动态内存分配的函数 calloc大小修改函数realloc今天我们来学习一下...
    99+
    2024-04-02
  • C语言编程数据在内存中的存储详解
    目录变量在计算机中有三种表示方式,原码反码,补码原码反码补码总结一下浮点数在内存的储存C语言中,有几种基本内置类型。 int unsigned int signed int cha...
    99+
    2024-04-02
  • 关于C语言中数据在内存中的存储详解
    目录前言一、数据类型介绍1.类型的基本归类1.整形家族2.浮点型家族3.构造类型4.指针类型5.空类型二、整型在内存中的存储1.原码、反码、补码2.内存中怎样存储3.大小端字节序1....
    99+
    2024-04-02
  • C语言结构体中内存对齐的问题理解
    目录前言思考结构体在内存中开辟空间时内存对齐的规则为什么存在内存对齐1.平台的原因2.性能的原因前言 学C的同学应该知道~ 想精通C语言就不得不面对—指针与内存 续上次指...
    99+
    2024-04-02
  • C语言详解float类型在内存中的存储方式
    目录1.例子2.浮点数存储规则1.例子 int main() { int n = 9; float *pFloat = (float *)&n; ...
    99+
    2024-04-02
  • C语言与C++中内存管理详解
    目录内存分布动态内存管理方式-堆区C语言动态内存管理C++动态内存管理new和delete的用法operator new与operator delete函数new和dele...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作