C/C++堆区专篇精讲

 更新时间:2022年10月26日 16:25:25   作者:划水猫  
一直以来总是对这个问题的认识比较朦胧,我相信很多朋友也是这样的,总是听到内存一会在栈上分配,一会又在堆上分配,那么它们之间到底是怎么的区别呢,让我们一起来看看

malloc

malloc开辟堆区内存。头文件stdlib.h,函数原形如下。

void*malloc(size_tsize); //返回值void指针,该指针就是开辟的内存地址,参数是开辟的字节数。

free

free释放堆区开辟的内存。头文件stdlib.h,函数原形如下。

voidfree(void*ptr); // 参数传入需要释放的堆区内存首地址。

程序:

#include<iostream>
#include<windows.h>
using namespace std;
int main() {
	int* p = (int*)malloc(20);  //void*  malloc(size) 返回自void指针,参数是字节数
	for (int i = 0; i < 5; i++) {
		p[i] = i;
		//*(p+i) = i;
	}
	cout << p[1] << "  " << *(p + 1) << endl;
	if (p) {
		free(p);  // void free(heap addr)
	}
	system("pause");
	return 0;
}

结果:

1 1

请按任意键继续. . .

C++ 中的new和delete是运算符开辟和释放堆区空间比C语言的malloc、free更高效,推荐使用。

new

返回堆区首元素的地址,可以开辟一个元素(开辟的时候可以赋值)、一维数组、二维数组。当使用new开辟二维数组的时候需要特别注意,返回的是数组指针,所以需要数组指针去接收堆区地址。

delete

delete释放堆区的时候数组需要加上[]

程序:

#include<iostream>
#include<windows.h>
using namespace std;
int main() {
	int* p1 = new int(3);  // 在堆区创建一个int类型数据,并且赋初值
	// int* p2 = new int(0, 1, 2, 3, 4);  // 无法初始化数组
	int* p3 = new int[4];  // 在堆区创建数组,不赋初值
	int(*p4)[3] = new int[2][3];  // 在堆区创建二维数组
	*(p3 + 1) = 1;
	cout << *p1 << endl;
	cout << *(p3 + 1) << endl;
	if (p1) {
		delete p1;
	}
	if (p3) {
		delete[] p3;
	}
	if (p4) {
		delete[] p4;
	}
	system("pause");
	return 0;
}

结果:

3

1 请按任意键继续. . .

memcpy

内存拷贝函数,从src源地址拷贝size字节到dest目标地址

头文件:cstring 函数原形

void*memcpy(void*dest,constvoid*src,std::size_tcount);

dest目标地址,src源地址,size拷贝的字节数

代码:

#include<iostream>
#include<string>
#include<windows.h>
using namespace std;
int main() {
	int num1[5] = { 0, 1, 2, 3, 4 };
	int* p = new int[5];
	memcpy(p, &num1, sizeof(num1));
	cout << *(p + 2) << endl;
	if (p) {
		delete[] p;
	}
	system("pause");
	return 0;
}

结果:

2

请按任意键继续. . .

memset

用于初始化新开辟的堆区内存,从dest目标地址开始,size个字节设置成数据ch

头文件:cstring 函数原形

void*memset(void*dest,intch,std::size_tcount);

dest目标地址,ch需要设置的值,size字节数

程序:

#include<iostream>
#include<windows.h>
using namespace std;
int main() {
	int* p = new int[5];
	memset(p, 0, 5 * sizeof(int));  // 将新开辟的的堆区数组设成0
	cout << *(p + 2) << endl;
	if (p) {
		delete[] p;
	}
	system("pause");
	return 0;
}

结果:

0

请按任意键继续. . .

到此这篇关于C/C++堆区专篇精讲的文章就介绍到这了,更多相关C++堆区内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 贪心算法 WOODEN STICKS 实例代码

    贪心算法 WOODEN STICKS 实例代码

    贪心算法 WOODEN STICKS 实例代码,需要的朋友可以参考一下
    2013-05-05
  • Qt控件之QPushButton使用及技巧

    Qt控件之QPushButton使用及技巧

    QPushButton类是Qt中用于创建按钮的控件类,它继承自QAbstractButton类,本文就来介绍一下Qt控件之QPushButton使用及技巧,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • C语言实现简单通讯录管理系统

    C语言实现简单通讯录管理系统

    这篇文章主要为大家详细介绍了C语言实现简单通讯录管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C语言二维数组的处理实例

    C语言二维数组的处理实例

    这篇文章主要介绍了C语言二维数组的处理实例,有需要的朋友可以参考一下
    2013-12-12
  • wince程序防止创建多个实例实现互斥作用

    wince程序防止创建多个实例实现互斥作用

    什么时候用的互斥?当你的程序只允许同时打开一个的时候,就可以通过互斥来实现,下面说的互斥,主要是针对防止程序创建多个实例这种情况来实现的
    2014-02-02
  • c++面试题字符串拷贝函数示例

    c++面试题字符串拷贝函数示例

    这个也算是企业招工里面比较常见的一道笔试面试题了,非常简单。个人觉得考的主要是对指针使用的熟练程度,还有对字符串类内部原理的掌握程度
    2013-12-12
  • C++实现打印两个有序链表公共部分的方法

    C++实现打印两个有序链表公共部分的方法

    这篇文章主要介绍了C++实现打印两个有序链表公共部分的方法,涉及C++针对有序链表的简单遍历、比较相关操作技巧,需要的朋友可以参考下
    2017-05-05
  • Window10下安装VS2022社区版的实现步骤(图文教程)

    Window10下安装VS2022社区版的实现步骤(图文教程)

    很多和同学们在接触c语言的时候都是使用VS,本文主要介绍了Window10下如何安装VS2022社区版的实现步骤,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • C++实现四叉树效果(附源码下载)

    C++实现四叉树效果(附源码下载)

    这篇文章主要介绍了C++实现四叉树效果(附源码下载),非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • 利用Qt实现仿QQ设置面板功能

    利用Qt实现仿QQ设置面板功能

    这篇文章主要为大家详细介绍了如何利用Qt实现仿QQ设置面板功能,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以了解一下
    2022-12-12

最新评论