`

堆和栈(二)

    博客分类:
  • C++
阅读更多
含有这种错误的函数每被调用一次就丢失一块内存。刚开始时系统的内存充足,你看不到错误。终有一次程序突然死掉,系统出现提示:内存耗尽
动态内存的申请与释放必须配对,程序中malloc与free的使用次数一定要相同,否则肯定有错误(new/delete同理)
(5)释放了内存却继续使用它
(11)程序中的对象调用关系过于复杂,实在难以搞清楚某个对象究竟是否已经释放了内存,此时应该重新设计数据结构,从根本上解决对象管理的混乱局面
(12)函数的return语句写错了,注意不要返回指向“栈内存”的“指针”或者“引用”,因为该内存在函数体结束时被自动销毁
(13)使用free或delete释放了内存后,没有将指针设置为NULL。导致产生“野指针”
【规则1】用malloc或new申请内存之后,应该立即检查指针值是否为NULL。防止使用指针值为NULL的内存
【规则2】不要忘记为数组和动态内存赋初值。防止将未被初始化的内存作为右值使用。
【规则3】避免数组或指针的下标越界,特别要当心发生“多1”或者“少1”操作
【规则4】动态内存的申请与释放必须配对,防止内存泄漏
【规则5】用free或delete释放了内存之后,立即将指针设置为NULL,防止产生“野指针”

3、指针与数组的对比
C++/C程序中,指针和数组在不少地方可以相互替换着用,让人产生一种错觉,以为两者是等价的
数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。数组名对应着(而不是指向)一块内存,其地址与容量在生命期内保持不变,只有数组的内容可以改变
指针可以随时指向任意类型的内存块,它的特征是“可变”,所以我们常用指针来操作动态内存。指针远比数组灵活,但也更危险
分享到:
评论

相关推荐

    浅析C语言中堆和栈的区别

    在计算机领域,堆栈是一个不容忽视的概念,我们编写的...C语言程序经过编译连接后形成编译、连接后形成的二进制映像文件由栈,堆,数据段(由三部分部分组成:只读数据段,已经初始化读写数据段,未初始化数据段即BBS)

    堆和栈的区别

    堆和栈的区别 一、预备知识—程序的内存分配 二、堆和栈的理论知识 三、windows进程中的内存结构

    堆与栈的区别

    3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的 全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另 一块区域。 - 程序结束后由系统释放。 4、...

    堆和栈区别.pdf

    一个由 c/C 编译的程序占用的内存分为以下几个部分 1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操 作方式类似于数据结构中的栈。...5、程序代码区—存放函数体的二进制代码。

    堆(heap)和栈(stack)的区别

    一、预备知识—程序的内存分配 二、例子程序 3.windows进程中的内存结构

    堆内存和栈内存详解 ESP

    3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后有系统释放 4、文字...

    关于C++使用指针 堆和栈的区别分析

    数据在内存的存放有以下几种形式 1.栈区–由编译器自动分配并且释放,该区域一般存放函数的参数值,局部变量的值等, ...函数参数和局部变量存放在栈中,函数运行结束或者返回系统就释放了他们所占用的内存空间,但是全

    静态区、堆、栈 区别

    3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后由系统释放。 4、...

    C++中的栈和堆的区别

    3、全局区(静态区)(static)―,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后有系统释放 4、...

    linux内存泄漏查找

    bin bin就是二进制(binary)英文缩写,该目录中存放Linux的常用命令,在有的版本中是一些和根目录下相同的目录。 /boot 该目录下存放的都是系统启动时要用到的程序,当用lilo引导Linux时,会用到这里的一些信息 /dev ...

    java堆栈的区别 -- 详解

    二、堆和栈的理论知识 2.1申请方式 stack: 由系统自动分配。 例如,声明在函数中一个局部变量 int b; 系统自动在栈中为b开辟空间 heap: 需要程序员自己申请,并指明大小,在c中malloc函数 如p1 = (char *)...

    C_C++问题总结

    C/C++问题总结 1. 关键字 1.1 const 1.1.1 常量 1.1.2 修饰指针 1.1.3 修饰函数参数与返回值 1.1.4 类中的应用 1.2 static 1.3 volatile 1.4 extern ...2.1 sizeof与strlen区别 ...3.20.2 堆和栈 3.20.3 栈溢出

    程序员面试题精选100题(C/C++)

    pdf版的,很清晰,对应届生找工作很有帮助的!

    求职c++后台工作的重点总结

    一、虚函数和纯虚函数的区别;二、堆和栈的区别;三、volitate有什么作用?等等

    iOS 内存管理机制 详细解读

    堆和栈的区别 3.1)申请方式和回收方式 3.2)申请后的系统响应 3.3)申请大小的限制 3.4)申请效率的比较 3.5)分配方式的比较 3.6)分配效率的比较 四. 内存分配的引入 4.1)什么行为会增加App的内存占用? 4.2)...

    java实现内存动态分配

    虽然Java中所有对象的存储空间都是在堆中分配的,但是这个对象的引用却是在栈中分配,也就是说在建立一个对象时在堆和栈中都分配内存,在堆中分配的内存实际存放这个被创建的对象的本身,而在栈中分配的内存只是存放...

    Java数据结构和算法中文第二版

    全书共分为15章,分别讲述了基本概念、数组、简单排序、堆和队列、链表、递归、进阶排序、二叉树、红黑树、哈希表及图形等知识。附录中则提供了运行专题Applet和例程、相关书籍和问题解答。本书提供了学完一门编程...

    数据结构与算法分析第二版 ---C语言描述(附加答案)

    表、栈和队列3.1 抽象数据类型(ADT)3.2 表ADT3.2.1 表的简单数组实现3.2.2 链表3.2.3 程序设计细节3.2.4 常见的错误3.2.5 双链表3.2.6 循环链表3.2.7 例子3.2.8 链表的游标实现3.3 栈ADT3.3.1 栈模型3.3.2 栈的...

    Java自学程序员必备+计算机基础+操作系统,组成原理,数据结构+自学必备,内功提升

    20、经常说的堆和栈原来是这么回事.md 21、数据的逻辑结构和物理结构.md 22、数据结构中的绝代双骄(1)数组.md 23、数据结构中的绝代双骄(2)链表.md 24、数据结构中的栈和队列这回懂了.md ……

    深入JVM内核—原理、诊断与优化

    第二周JVM运行机制简介堆、栈、方法区等JVM启动流程内存模型和volatile实例解释和编译运行的概念介绍JVM的内部结构、启动流程以及内存模型。并介绍JVM字节码的执行方式。第三周常用JVM参数堆的分配参数栈分 资源太大...

Global site tag (gtag.js) - Google Analytics