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

C++动态空间申请

1.动态分配内存的概述

在数组一章中,介绍过数组的长度是预先定义好的,在整个程序中固定不变,但是在实际的编程中,往往会发生这种情况,即所需的内存空间取决于实际输入的数据,而无法预先确定 。为了解决上述问 题,C ++ 语言提供了一些关键字,可以按需要动态的分配内存空间,也可把不再使用的空间回收再次利用。C语言中用 malloc/free . . .; C++里用new/delete;

2. 内存分区

进程:可执行文件 从运行到结束 整个动态的过程 就叫进程。(占内存空间)
32 位平台 每一个进程 占 4G 空间(虚拟空间)

3. 静态分配、动态分配

3.1 静态分配

1 、在程序编译或运行过程中,按事先规定大小分配内存空间的分配方式。 int a [5]
2 、必须事先知道所需空间的大小。
3 、分配在栈区或全局变量区,一般以数组的形式

3.2 动态分配

1 、在程序运行过程中,根据需要大小自由分配所需空间。
2 、按需分配。
3 、分配在堆区,一般使用特定的关键字进行分配

4. newdelete

4.1 newdelete操作基本类型空间

new申请堆区空间 delete 释放空间
申请int型空间,首先就要定义一个int型指针;从堆区申请这个空间,你要用指针去指向这个空间。释放空间 只需要给空间起始地址就行了,new和delete是成对出现的;如果没有delete的话,只要进程不结束,那么这个堆区空间一直存在,不太安全;
int * p = NULL ;
p = new int ; // 从堆区申请 int 类型大小的空间
* p = 10 ;
cout << "*p=" <<* p << endl ; //10
// 释放空间
delete p ;
//new 申请空间的同时 初始化空间内容
int * p1 = NULL ;
p1 = new int ( 10 ); //用小括号,数组初始化用大括号
cout << "*p=" <<* p << endl ; //10
delete p1 ;

4.2 newdelete操作数组空间

new与[]结合表示申请数组空间 delete释放的时候也需要[]

#include<iostream>
using namespace std;
int main()
{
    int *arr = NULL;
    arr = new int[5]{ 1,2,3,4,5 };
    int i = 0;
    for (i = 0; i < 5; i++)
    {
        cout << arr[i] << "  ";
    }
    cout << endl;

    delete [ ] arr;  //如果new有[ ],delete也要有 [ ]

    return 0;
}

相关文章:

  • switch循环语句
  • 牛客练习赛#84 F 莫比乌斯反演+杜教筛+技巧+斐波那契数列和gcd的结论+矩阵快速幂
  • ZZNUOJ_用C语言编写程序实现1342:支配值数目(附完整源码)
  • java毕业设计后勤管理系统餐饮评价监督系统(附源码、数据库)
  • 前端基础学习笔记
  • 【TS】联合类型--类型断言--类型推断
  • 谈笑风声的秘密
  • QT影城网上售票系统
  • NetCDF数据在ArcMap中的使用
  • 打怪升级(考验思路)