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

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;
}

相关文章:

  • WEB安全之javascript基础(一):js的引入方法注释变量数据类型
  • 【node进阶】深度解析Express框架--路由、中间件
  • 硬件设计基础----通信协议UART
  • Python的基础语法
  • 详解CAN总线:CAN总线报文格式—过载帧
  • 论如何参与一个开源项目(上)
  • 【一起学Rust | 开源项目】效率提升工具espanso——在日常输入中使用代码提示
  • 【youcans 的图像处理学习课】11. 形态学图像处理(下)
  • 谈谈对链表的理解
  • create-react-app打包优化
  • Mycat 安装以及应用
  • JS面向对象编程之类(1)
  • Pytorch-张量tensor详解(线性回归实战)
  • UnityJSON持久化数据
  • 最小生成树(Prim、Kruskal)算法
  • 【JavaScript】通过闭包创建具有私有属性的实例对象
  • angular组件开发
  • Cumulo 的 ClojureScript 模块已经成型
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • Idea+maven+scala构建包并在spark on yarn 运行
  • If…else
  • JavaScript DOM 10 - 滚动
  • k8s 面向应用开发者的基础命令
  • Leetcode 27 Remove Element
  • Linux下的乱码问题
  • scala基础语法(二)
  • vuex 学习笔记 01
  • 程序员该如何有效的找工作?
  • 创建一个Struts2项目maven 方式
  • 翻译--Thinking in React
  • 反思总结然后整装待发
  • 批量截取pdf文件
  • 世界上最简单的无等待算法(getAndIncrement)
  • 收藏好这篇,别再只说“数据劫持”了
  • 为视图添加丝滑的水波纹
  • 我看到的前端
  • nb
  • 【干货分享】dos命令大全
  • 移动端高清、多屏适配方案
  • 支付宝花15年解决的这个问题,顶得上做出十个支付宝 ...
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • (1)Android开发优化---------UI优化
  • (2)STM32单片机上位机
  • (30)数组元素和与数字和的绝对差
  • (Python) SOAP Web Service (HTTP POST)
  • (二)fiber的基本认识
  • (论文阅读11/100)Fast R-CNN
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (图)IntelliTrace Tools 跟踪云端程序
  • (一)python发送HTTP 请求的两种方式(get和post )
  • (原創) 如何讓IE7按第二次Ctrl + Tab時,回到原來的索引標籤? (Web) (IE) (OS) (Windows)...
  • (转)使用VMware vSphere标准交换机设置网络连接
  • (转)用.Net的File控件上传文件的解决方案
  • (转载)PyTorch代码规范最佳实践和样式指南
  • (转载)虚函数剖析