欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

c++ 动态内存分配相关总结

时间:2022-08-22 09:22:11|栏目:C代码|点击:

  下面随笔是关于c++动态内存分配。

动态申请内存操作符 new

  • new 类型名T(初始化参数列表)
  • 功能:在程序执行期间,申请用于存放T类型对象的内存空间,并依初值列表赋以初值。
  • 结果值:成功:T类型的指针,指向新分配的内存;失败:抛出异常。

释放内存操作符delete

  • delete 指针p
  • 功能:释放指针p所指向的内存。p必须是new操作的返回值。
//例1 动态创建对象举例

#include <iostream>

using namespace std;

class Point {

public:

Point() : x(0), y(0) {

  cout<<"Default Constructor called."<<endl;

}

Point(int x, int y) : x(x), y(y) {

  cout<< "Constructor called."<<endl;

}

~Point() { cout<<"Destructor called."<<endl; }

  int getX() const { return x; }

  int getY() const { return y; }

  void move(int newX, int newY) {

    x = newX;

    y = newY;

}

private:

int x, y;

};

int main() {

  cout << "Step one: " << endl;

  Point *ptr1 = new Point; //调用默认构造函数

  delete ptr1; //删除对象,自动调用析构函数

  cout << "Step two: " << endl;

  ptr1 = new Point(1,2);

  delete ptr1;

  return 0;

}
运行结果:

Step One:

Default Constructor called.

Destructor called.

Step Two:

Constructor called.

Destructor called.

分配和释放动态数组

  • 分配:new 类型名T [ 数组长度 ]

数组长度可以是任何表达式,在运行时计算

  • 释放:delete[] 数组名p

释放指针p所指向的数组。
p必须是用new分配得到的数组首地址。

//例2 动态创建对象数组举例

#include<iostream>

using namespace std;

class Point { //类的声明同例6-16,略 };

int main() {

  Point *ptr = new Point[2]; //创建对象数组

  ptr[0].move(5, 10); //通过指针访问数组元素的成员

  ptr[1].move(15, 20); //通过指针访问数组元素的成员

  cout << "Deleting..." << endl;

  delete[] ptr; //删除整个对象数组

  return 0;

}
运行结果:

Default Constructor called.

Default Constructor called.

Deleting...

Destructor called.

Destructor called.

动态创建多维数组

new 类型名T[第1维长度][第2维长度]…;

如果内存申请成功,new运算返回一个指向新分配内存首地址的指针。

  例如:

  char (*fp)[3];

  fp = new char[2][3];

//例3 动态创建多维数组

#include <iostream>

using namespace std;

int main() {

  int (*cp)[9][8] = new int[7][9][8];

  for (int i = 0; i < 7; i++)

    for (int j = 0; j < 9; j++)

      for (int k = 0; k < 8; k++)

        *(*(*(cp + i) + j) + k) =(i * 100 + j * 10 + k);

  for (int i = 0; i < 7; i++) {

    for (int j = 0; j < 9; j++) {

      for (int k = 0; k < 8; k++)

        cout << cp[i][j][k] << " ";

        cout << endl;

    }

    cout << endl;

  }

  delete[] cp;

  return 0;

}

上一篇:实现一个random shuffle算法示例

栏    目:C代码

下一篇:C语言 超详细总结讲解二叉树的概念与使用

本文标题:c++ 动态内存分配相关总结

本文地址:http://www.codeinn.net/misctech/211498.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有