C/C++堆区专篇精讲

目录
  • malloc
  • free
  • new
  • delete
  • memcpy
  • memset

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++堆区内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解C++内存的代码区,全局区,栈区和堆区

    目录 代码区: 全局区: 栈区 堆区 总结 今天无意中刷到了一篇关于c++内存的帖子,我发现那个人好像写的不太对,然后同时我自己也发现我对一块还不够了解,所以我干脆就自己去了解整理了一下:首先我们要大概知道四个区都是干什么的 代码区: 顾名思义,就是存放我们写的代码的地方,不过要注意的是存放的是二进制代码. 注意:我们写的所有的写的代码(包括注释.变量.语句等)都会放到代码区中. 全局区: 存放全局,静态变量以及常量. 注意: 1.全局区里有一个部分叫常量区,储存的是常量,如const修饰的全局

  • C++程序内存栈区与堆区模型案例分析

    目录 栈区: 栈区代码演示: 堆区: 堆区代码演示: new操作符: new操作符代码演示: 栈区: 由编译器自动分配释放,存放函数的参数值,局部变量等(由编译器管理其“生死”) 注意事项:不要返回局部变量的地址,栈区开辟的数据由编译器自动释放 栈区代码演示: //内存四区-栈区 /* 栈区: 由编译器自动分配释放,存放函数的参数值,局部变量等(由编译器管理其"生死") 注意事项:不要返回局部变量的地址,栈区开辟的数据由编译器自动释放 */ #include <iostream&

  • C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)

    内存分区模型 1 代码区 2 全局区 // 全局变量.静态变量.常量 #include <iostream> using namespace std; // 全局变量.静态变量.常量 //全局变量 int g_a=10; int g_b=10; //const修饰的全局常量 const int c_g_a = 10; const int c_g_b = 10; int main() { //创建普通局部变量 int a = 10; int b = 10; cout << "

  • C++内存四区之代码区、全局区、栈区和堆区

    C++内存四区 C++ 在程序执行时,将内存大致分为代码区,全局区,栈区和堆区四个区域.不同的区域存储不同的数据,赋予不同的生命周期,能够更灵活地进行编程. 代码区:存放函数体的二进制代码,由操作系统管理创建,代码区时共享的,对于频繁被执行的程序,只需要存有一份代码即可: 全局区:存放全局变量和静态变量以及常量,在程序结束后由操作系统释放: 栈区:由编译其自动分配释放,存放函数的参数值以及局部变量等: 堆区:一般由程序员通过 new 开辟空间,进行分配和释放,若程序员不释放,则程序结束时由操作系

  • C/C++堆区专篇精讲

    目录 malloc free new delete memcpy memset malloc malloc开辟堆区内存.头文件stdlib.h,函数原形如下. void*malloc(size_tsize); //返回值void指针,该指针就是开辟的内存地址,参数是开辟的字节数. free free释放堆区开辟的内存.头文件stdlib.h,函数原形如下. voidfree(void*ptr); // 参数传入需要释放的堆区内存首地址. 程序: #include<iostream> #incl

  • MySQL视图和索引专篇精讲

    目录 视图View 代码实现: 索引index 建立索引 删除索引 数据库版本:mysql8.0.27 如果以下代码执行有问题欢迎一起探讨 视图View 什么是视图? 视图是一个虚拟表,是sql语句的查询结果,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据,在使用视图时动态生成.视图的数据变化会影响到基表,基表的数据变化也会影响到视图[insertupdate delete ] ; 创建视图需要create view 权限,并且对于查询涉及的列有select权限:使用cre

  • Jetpack Compose状态专篇精讲

    目录 1.remember 2.rememberSaveable 3.状态提升 4.状态管理 将Composable作为可信来源 将状态容器作为可信来源 将 ViewModel 作为可信来源 应用中的状态是指可以随时间变化的任何值.这是一个非常宽泛的定义,从 Room 数据库到类的变量,全部涵盖在内. 由于Compose是声明式UI,会根据状态变化来更新UI,因此状态的处理至关重要.这里的状态你可以简单理解为页面上展示的数据,那么状态管理就是处理数据的读写. 1.remember remembe

  • Java 数据结构与算法系列精讲之二叉堆

    目录 概述 优先队列 二叉堆 二叉堆实现 获取索引 添加元素 siftUp 完整代码 概述 从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章. 优先队列 优先队列 (Priority Queue) 和队列一样, 是一种先进先出的数据结构. 优先队列中的每个元素有各自的优先级, 优先级最高的元素最先得到服务. 如图: 二叉堆 二叉堆 (Binary Heap) 是一种特殊的堆, 二叉堆具有堆的性质和二叉树的性质. 二叉堆中的任意一节点的值总是大于等于其孩子节点值. 如图: 二

  • 剑指Offer之Java算法习题精讲链表专题篇

    题目一  解法 /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ class Solut

  • 剑指Offer之Java算法习题精讲二叉树专题篇下

    题目一  解法 /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; *

  • 剑指Offer之Java算法习题精讲二叉树专题篇上

    来和二叉树玩耍吧~ 题目一 解法 /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val

  • 详谈java 堆区、方法区和栈区

    堆区:只存放类对象,线程共享: 方法区:又叫静态存储区,存放class文件和静态数据,线程共享; 栈区:存放方法局部变量,基本类型变量区.执行环境上下文.操作指令区,线程不共享; class A { private String a = "aa"; //a在堆区 public boolean methodB() { String b = "bb"; //b在栈区 final String c = "cc"; // c在栈区 } } 以上这篇详谈j

  • vue-路由精讲 二级路由和三级路由的作用

    1.我们继续上一个案例 vue -- 路由精讲制作导航 -- 从无到有 ,在 about文件夹下 创建一些文件夹.如下: 2.编写about.vue代码.当我们点击导航中 "关于我们" ,就会显示该部分内容.代码中写了四个可供点击后可以跳转的模块.和 <router-view></router-view> 表示你点击了哪个组件,哪个组件就会渲染到这里来. 其中注意:css样式,我们直接引入bootstrap中的导航的样式,在标签中直接添加class属性的值就可以

随机推荐