动态内存分配.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

动态内存分配

如果形参是一个二维数组,必须指定第一维度的大小,a[][10]合法,但是a[][]非法,编译时就确定数组的长度,但很多场景下需要每个长度不一的二维数组

因为使用new对数组进行动态分配,返回数组中第一个元素的地址,所有创建二维数组则第二维度只保留指针

#includeiostream

usingnamespacestd;

templatellt;classT

voidalloc_two_dimensional(T_,intnumber_of_rows,intnumber_of_columns){

//先动态创建保存数组元素的指针

int**matrix=newT*[number_of_rows];

//然后再依次创建一维数组

for(introw=0;rownumber_of_rows;row++){

matrix[row]=newT[number_of_columns];

//修改二维数组的值

matrix[1][1]=10;

matrix[2][2]=10;

matrix[3][3]=10;

matrix[4][4]=10;

//遍历二维数组

for(inti=0;inumber_of_rows;i++){

for(intj=0;jnumber_of_columns;j++){

coutmatrix[i][j]\t

coutendl;

//释放内存

//首先释放保存在数组中的每一个元素指向的数组

for(inti=0;inumber_of_rows;i++){

delete[]matrix[i];

//释放最外层的数组

delete[]matrix;

intmain(){

inta;

alloc_two_dimensional(a,9,12);

delete操作符

释放由new操作符动态分配的内存空间,调用对象关联类型的析构函数

只能操作指针类型对象

单个对象使用delete运算符,但多个对象的数组则需要使用delete[]运算符

#includeiostream

intmain(){

int*y=newint(10);

//释放指针指向的单个对象的内存,调用对象的析构函数

deletey;

int*a=newint[10]{1,2,3,4};

//释放指针指向的数组对象所有内存,遍历依次调用数组中元素对应的析构函数

delete[]a;

使用场景:动态分配的内存空间(存储空间)不在需要时

文档评论(0)

152****4498 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档