动态分配内存的风险

发布时间:2024年01月14日

1. 悬挂指针问题

在指针释放之后要将指针置空

delete ptr;
ptr = nullptr;

2.内存碎片问题

频繁的申请与释放小块内存会造成大量的内存碎片。

3.内存申请与释放问题

C与C++的内存申请与释放最好不要混用。

4.复制内存

基本语法

void* memcpy(void* _Dst, void* _Src, size_t size);

该函数将_Src处的内存复制到_Dst中,复制的长度为size

示例

#include <iostream>

int main()
{
	int A[5]{ 1001,1002,1003,1004,1005 };
	int* ptrA = new int[5];
	memcpy(ptrA, A, sizeof(A)); 
	for (int i = 0; i < sizeof(A) / sizeof(int); i++)
		std::cout << "ptrA[" << i << "] = " << ptrA[i] << std::endl;
}

结果

ptrA[0] = 1001
ptrA[1] = 1002
ptrA[2] = 1003
ptrA[3] = 1004
ptrA[4] = 1005

5.设置内存

基本语法

void* memset(void* _Dst,int val, size_t size);

将目标区域的每个字节的内容都设置为val的值,长度为size。

示例

#include <iostream>

int main()
{
	int A[5]{ 1001,1002,1003,1004,1005 };
	int* ptrA = new int[5];
	memset(ptrA, 0, sizeof(A));
	for (int i = 0; i < sizeof(A) / sizeof(int); i++)
		std::cout << "ptrA[" << i << "] = " << ptrA[i] << std::endl;
}

结果

ptrA[0] = 0
ptrA[1] = 0
ptrA[2] = 0
ptrA[3] = 0
ptrA[4] = 0
文章来源:https://blog.csdn.net/m15306436864/article/details/135583417
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。