zoukankan      html  css  js  c++  java
  • 自由存储区内存的分配与释放

     1、堆的概念
    通常定义变量(或对象),编译器在编译时都可以根据该变量(或对象)的类型知道所需内存空间的大小,从而系统在适当的时候为他们分配确定的存储空间。这种内存分配称为静态存储分配

    有些操作对象只在程序运行时才能确定,这样编译时就无法为他们预定存储空间,只能在程序运行时,系统根据要求进行内存分配,这种方法称为动态存储分配。所有动态存储分配都在堆区中进行。

     2、堆空间申请、释放的方法
    在C++中,申请和释放堆中分配的存贮空间,分别使用new和delete的两个运算符来完成:
        指针变量名=new 类型名(初始化式);
        delete 指针名;

    例如:
        int *pi=new int(0);
    它与下列代码序列大体等价:
        int ival=0, *pi=&ival;
    区别:pi所指向的变量是由库操作符new()分配的,位于程序的堆区中,并且该对象未命名。 2、堆空间申请、释放的方法
    在C++中,申请和释放堆中分配的存贮空间,分别使用new和delete的两个运算符来完成:
        指针变量名=new 类型名(初始化式);
        delete 指针名;

    例如:
        int *pi=new int(0);
    它与下列代码序列大体等价:
        int ival=0, *pi=&ival;
    区别:pi所指向的变量是由库操作符new()分配的,位于程序的堆区中,并且该对象未命名。

    一定注意:delete []pc是将n个字符的空间释放,而用delete pc则只释放了一个字符的空间;

  • 相关阅读:
    jquery的 $.Event()
    自动化构建种常用命令
    原生js实现addClass,removeClass,hasClass方法
    43.放苹果(递归练习)
    43.放苹果(递归练习)
    43.放苹果(递归练习)
    43.放苹果(递归练习)
    42.递归算法---数的划分
    42.递归算法---数的划分
    42.递归算法---数的划分
  • 原文地址:https://www.cnblogs.com/htys/p/3312424.html
Copyright © 2011-2022 走看看