当前位置: 首页 > article >正文

【C语言】(13)堆和栈

在C语言中,理解和正确使用堆(Heap)和栈(Stack)是至关重要的。这两部分是程序内存中的关键区域,用于存储变量和数据。

栈(Stack)

栈是自动管理的内存区域,主要用于存储函数调用的上下文(如局部变量和返回地址)。

特点

  • 自动分配和释放。
  • 快速访问,因为数据总是位于栈顶。
  • 有大小限制,通常由操作系统设置。
  • 超出栈大小会导致栈溢出。

示例

void function() {
    int localVar = 10; // 在栈上分配
}

堆(Heap)

堆是动态内存区域,由程序员手动管理,适用于存储生命周期长或大小不确定的数据。

特点

  • 手动分配和释放。
  • 相对栈而言访问速度较慢。
  • 空间大小理论上仅受限于系统的可用内存。
  • 动态分配的内存需要手动释放,否则会导致内存泄漏。

示例

#include <stdlib.h>

void function() {
    int *heapVar = (int *)malloc(sizeof(int)); // 在堆上动态分配
    *heapVar = 10;
    free(heapVar); // 释放内存
}

内存的申请与释放

动态内存申请

  • 使用malloccalloc函数分配。
  • 分配的内存未初始化(malloc)或初始化为零(calloc)。
  • 返回void*指针,通常需要类型转换。

动态内存释放

  • 使用free函数释放。
  • 释放后应将指针设置为NULL以避免野指针。

示例

#include <stdlib.h>

int main() {
    // 申请内存
    char *str = (char *)malloc(50 * sizeof(char));

    // 使用内存
    if (str != NULL) {
        // ...

        // 释放内存
        free(str);
        str = NULL;
    }

    return 0;
}

注意事项

  • 栈内存适用于小量数据和局部变量。
  • 大型数据或复杂结构应在堆上分配。
  • 动态内存需要显式释放,避免内存泄漏。
  • 栈内存通常更快但大小有限,适合短生命周期的数据。
  • 堆内存更灵活但管理复杂,适合长生命周期的数据。
  • 理解栈和堆的使用场景和限制对于编写高效和稳定的程序至关重要。

http://www.kler.cn/a/231233.html

相关文章:

  • C#面试常考随笔7:什么是匿名⽅法?还有Lambda表达式?
  • 项目测试之MockMvc
  • doris:数据更新概述
  • 级数论存在重大错误的原因:中学数学对无穷数列的认识存在重大错误
  • 我的求职面经:(1)C++里指针和数组的区别
  • 拦截器快速入门及详解
  • 【推荐算法】userid是否需要建模
  • PCIE Order Set
  • excel统计分析——成组数据秩和检验
  • 秘塔科技推出AI搜索产品「秘塔AI搜索」
  • Windows 安装 MySQL 最新最简教程
  • 【AG32VF407】国产MCU+FPGA,更新官方固件解决8Mhz内部晶振不准,Verilog实测7.9Mhz!
  • ubuntu 安装 kvmQemu no active connection to install on
  • 百卓Smart管理平台 uploadfile.php 文件上传漏洞复现(CVE-2024-0939)
  • 第三百一十二回
  • 浏览器F12调试
  • QT设置qss
  • Golang 基础 环境配置和包管理
  • Golang 并发 生产者消费者模式
  • 《MySQL 简易速速上手小册》第2章:数据库设计最佳实践(2024 最新版)
  • uniapp 开发App 权限授权 js-sdk
  • win10系统连接WiFi,输入正确密码,但还是提示错误
  • FPS游戏框架漫谈第二十二天
  • 【Eclipse插件开发】3工作台workbench探索【下篇】
  • ftp安装脚本文档
  • 【Git】08 多人单分支协作场景