C++中为什么要使用动态内存

 更新时间:2022年02月07日 10:41:47   作者:骆驼胡杨  
大家好,本篇文章主要讲的是C++中为什么要使用动态内存,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下

为什么要使用动态内存

1.按需分配,根据需要分配内存,不浪费

int main(void) {
	int money[10] = { 1, 2, 3 ,4, 5, 6, 7, 8, 9, 10 };	//工钱
	int len = sizeof(money) / sizeof(money[0]);			//money数组的长度
	int num = 20;		//人数
	int *salary = 0;	//薪资

	//给salary指针分配num个内存
	salary = new int[num];

	//方式一, 逐个赋值
	/*for (int i = 0; i < len; i++) {
		*(salary + i) = money[i];
	}*/

	//方式二, 使用memcpy内存拷贝
	//memcpy(目标, 源数组, 数组的字节);
	memcpy(salary, money, sizeof(money));

	for (int i = len; i < num; i++) {
		*(salary + i) = 666;	//后面的元素全部赋值为666
	}

	for (int i = 0; i < num; i++) {
		cout << "第" << i+1 << "个员工的薪资是: " << *(salary + i) << endl;
	}

	system("pause");
	return 0;
}

在这里插入图片描述

2.被调用函数之外需要使用被调用函数内部的指针对应的地址空间

#include  <iostream>
#include <Windows.h>
#include <string.h>

using namespace std;


//方式一, 返回分配给指针的地址
int* copy1(int count) {
	int* ap = NULL;

	//malloc是C语言中的动态内存分配操作符
	ap = (int*)malloc(sizeof(int) * count);	

	//new是C++中的动态内存分配操作符
	//ap = new int[count];

	if (ap == NULL) {
		exit(1);
	}

	for (int i = 0; i < count; i++) {
		*(ap + i) = 100 + i;
	}
	return ap;		//返回指针的地址
}

//方式二, 使用二级指针
void copy2(int** ap, int len) {
	
	*ap = (int*)malloc(sizeof(int) * len);
	if (*ap == NULL) {
		exit(1);
	}

	for (int i = 0; i < len; i++) {
		*(*ap + i) = 100 + 1;
	}
}

int main(void) {
	int* p = NULL;

	//方式一, 接收copy1函数返回指针的地址
	//p = copy1(10);
	
	//方式二, 使用二级指针
	copy2(&p, 10);

	for (int i = 0; i < 10; i++) {
		cout << "第" << i+1 << "个员工的薪资是: " << *(p+ i) << endl;
	}

	//c 语言中的释放内存函数,相当于 delete
	free(p);	

	system("pause");
	return 0;
}
C 内存分配: 
void *malloc(size_t size); 		// 分配内存
void free(void *); 						// 释放内存
malloc 在内存的动态存储区中分配一块长度为 size 字节的连续区域返回该区域的首地址.

3.突破栈区的限制,可以给程序分配更多的内存

#include  <iostream>
#include <Windows.h>

using namespace std;

//栈区的空间大小是有限的, 在Windows系统中一般有 1-2 M的内存
void demo1() {
	int a1[102400 * 2];			//100k * 2 * 4 = 800k
	//int a1[102400 * 3];		//100k * 3 * 4 = 1200k

	a1[0] = 1;
	cout << "This is a demo!" << endl;
}

//堆空间的大小是有限的, 在Windows10系统的限制是 2G
void demo2() {
	int* p = NULL;

	p = (int*)malloc(1024 * 1000 * 1000 * 2);	//大约2G
	p[0] = 1;
	cout << "This is a stack demo!" << endl;
}

int main(void) {
	//栈空间
	//demo1();

	//堆空间
	demo2();

	system("pause");
	return 0;
}

在这里插入图片描述

到此这篇关于C++中为什么要使用动态内存的文章就介绍到这了,更多相关C++动态内存内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言实现简易通讯录

    C语言实现简易通讯录

    这篇文章主要为大家详细介绍了C语言实现简易通讯录,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • C语言之快速排序算法(递归Hoare版)介绍

    C语言之快速排序算法(递归Hoare版)介绍

    大家好,本篇文章主要讲的是C语言之快速排序算法(递归Hoare版)介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2021-12-12
  • 用C++实现strcpy(),返回一个char*类型的深入分析

    用C++实现strcpy(),返回一个char*类型的深入分析

    本篇文章是对用C++实现strcpy(),返回一个char*类型进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++实现二维图形的傅里叶变换

    C++实现二维图形的傅里叶变换

    这篇文章主要介绍了C++实现二维图形的傅里叶变换的方法,是C++程序设计里一个重要的应用,需要的朋友可以参考下
    2014-08-08
  • C语言创建动态dll和调用dll(visual studio 2013环境下)

    C语言创建动态dll和调用dll(visual studio 2013环境下)

    本篇文章主要介绍了C语言创建动态dll和调用dll(visual studio 2013环境下),非常具有实用价值,需要的朋友可以参考下
    2017-11-11
  • C++ 的三种访问权限与三种继承方式

    C++ 的三种访问权限与三种继承方式

    我们知道C++中的类,有三种访问权限(也称作访问控制),它们分别是public、protected、private,C++中继承的方式还有多种。下面通过本文给大家详细介绍,对c++中的访问权限和继承方式感兴趣的朋友一起看看吧
    2016-11-11
  • 深入探讨C++父类子类中虚函数的应用

    深入探讨C++父类子类中虚函数的应用

    本篇文章是对C++父类子类中虚函数的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 在iOS中给视频添加滤镜的方法示例

    在iOS中给视频添加滤镜的方法示例

    这篇文章主要介绍了在iOS中给视频添加滤镜的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • C语言中条件编译详解

    C语言中条件编译详解

    预处理程序提供了条件编译的功能。可以按不同的条件去编译不同的程序部分,因而产生不同的目标代码文件。这对于程序的移植和调试是很有用的。条件编译有三种形式,下面分别介绍。
    2017-05-05
  • C语言中进行大小写字母转化的示例代码

    C语言中进行大小写字母转化的示例代码

    C语言标准库中提供了用于大小写转换的函数,使得这一操作变得简单而高效,本文将详细介绍如何在C语言中进行大小写字母的转换,包括相关的函数和示例代码,需要的朋友可以参考下
    2024-03-03

最新评论