memset()函数与memcpy()函数知识总结—结构体中有指针变量
当自定义结构体中指针成员时,在使用memcpy()函数和memset()函数时需要注意出现内存重复释放和内存泄漏的问题。
1.memcpy()函数
1.直接使用memcpy()函数拷贝结构体内容只是将该结构体所占用的内存空间进行拷贝,那么针对指针变量而言该仅是1个4字节(32位系统)的内存空间,而指针指向的真实内存空间则无法拷贝,也可理解常说的“浅拷贝”:即将stTT1.p的值(即内存地址)赋值给stTT2.p,此时stTT1.p和stTT2.p的值相同,指向同一片内存空间,即存在释放时重复释放的风险,代码示例:
程序示例
#include "pch.h"
#include <iostream>
struct stTest
{
int a;
int * p;
};
int main()
{
stTest stTT1, stTT2;
stTT1.p = (int *)malloc(sizeof(int) * 100);
stTT2.p = (int *)malloc(sizeof(int) * 100);//注释掉也能运行
memset(stTT1.p, 0, sizeof(int) * 100);
memset(stTT2.p, 0, sizeof(int) * 100);//注释掉也能运行
for (int i = 0; i < 100; i++)
{
stTT1.p[i] = 2 * i + 1;
}
memc