malloc和free(3)——malloc()申请内存得到指针,通过memcpy()拷贝数据到指针所指内存,指针没有改变,调用free()释放内存不会报错
来源:互联网 发布:java分布式开发面试题 编辑:程序博客网 时间:2024/06/05 12:18
malloc和free(3)——malloc()申请内存得到指针,通过memcpy()拷贝数据到指针所指内存,指针没有改变,调用free()释放内存不会报错
#include<stdlib.h> //malloc()头文件#include<iostream>using namespace std;//数组指针int main(){int len = 10;//声明时候赋值NULLdouble *Parr1D1 = NULL;cout<<"Parr1D1 before malloc: "<<Parr1D1<<endl; //Parr1D1的值是一个指针,顺着这个指针可以从内存中找到数据//cout<<"Parr1D1 before malloc: "<<*Parr1D1<<endl; //想看看这个指针所指内存处的内容,结果程序执行不下去,之后的cout什么都不输出//因为只声明了指针,没有对指针分配内存,这个指针此时的数值是0,0这个位置没有什么东西//所以此时这个指针自己还不知道自己将要指向的内存片段在哪里cout<<"&Parr1D1 before malloc: "<<&Parr1D1<<endl; //&Parr1D1指的是这个指针在内存中的存储位置//malloc函数是一种分配长度为num_bytes字节的内存块的函数,//可以向系统申请分配指定size个字节的内存空间Parr1D1 = (double*)malloc(len*sizeof(double));//从此指针知道自己所指向的内存的地址cout<<"Parr1D1 after malloc: "<<Parr1D1<<endl;//分配好内存后,把这段内存的首地址赋值给Parr1D1,因此Parr1D1的值不再是0cout<<"*Parr1D1 after malloc: "<<*Parr1D1<<endl;//分配内存后,可以看到这个指针所指内存处的内容,系统自动初始化为0cout<<"&Parr1D1 after malloc: "<<&Parr1D1<<endl;//Parr1D1这个指针在内存中的存储位置是不会改变的,即指针本身的地址不改变/////////////////////////////////////////////cout<<endl<<"&Parr1D1 before memcpy: "<<&Parr1D1<<endl;cout<<endl<<"Parr1D1[i]: before memcpy: ";for(int i=0; i<len; i++){cout<<Parr1D1[i]<<" ";}cout<<endl;///////////////////////////////////////////////报错:声明时候不能初始化 variable "data" may not be initialized//double data[len] ={ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };//只好先声明后初始化double data[len];cout<<endl<<"data[i]: ";for(int i=0; i<len; i++){data[i] = i;cout<<data[i]<<" ";}cout<<endl;//memcpy指的是c和c++使用的内存拷贝函数//memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。//void *memcpy(void *dest, const void *src, size_t n);//数组名称就是这个数组的首地址,//从data所指内存处,拷贝一串数据到Parr1D1这个指针所指的内存片段,数据长度是len*sizeof(double)//这样一份数据就变成两份,占用两份内存,多了一份内存开销memcpy(Parr1D1,data,len*sizeof(double));/////////////////////////////////////////////cout<<endl<<"&Parr1D1 after memcpy: "<<&Parr1D1<<endl;cout<<endl<<"Parr1D1[i]: after memcpy: ";for(int i=0; i<len; i++){cout<<Parr1D1[i]<<" ";}/////////////////////////////////////////////free(Parr1D1);return 0;}
输出:
Parr1D1 before malloc: 0&Parr1D1 before malloc: 0x7ffd99159f68Parr1D1 after malloc: 0xa4a1f0*Parr1D1 after malloc: 0&Parr1D1 after malloc: 0x7ffd99159f68&Parr1D1 before memcpy: 0x7ffd99159f68Parr1D1[i]: before memcpy: 0 0 0 0 0 0 0 0 0 0 data[i]: 0 1 2 3 4 5 6 7 8 9 &Parr1D1 after memcpy: 0x7ffd99159f68Parr1D1[i]: after memcpy: 0 1 2 3 4 5 6 7 8 9
阅读全文
0 0
- malloc和free(3)——malloc()申请内存得到指针,通过memcpy()拷贝数据到指针所指内存,指针没有改变,调用free()释放内存不会报错
- malloc和free(1)——malloc()申请内存得到指针,指针没有改变,用free()释放内存,不会报错
- malloc和free(2)——malloc()申请内存得到指针,指针被改动,用free释放内存报错
- 指针--内存 malloc free
- 使用二级指针分配和释放内存示例 malloc(), free()
- malloc,free动态申请释放内存机制
- C++ 指针的malloc、memcpy和 free
- stm32 使用malloc申请内存和free释放内存造成的内存碎片测试
- 内存分配—malloc()和free()
- malloc内存分配与free内存释放
- C 笔记 free()释放一个非malloc() 申请的内存
- malloc与free 动态内存的申请与释放
- 二维指针malloc和free
- 指针申请内存和释放
- 内存分配,malloc()和free()
- malloc free内存分配
- 动态分配内存malloc free
- Malloc与free内存的分配和释放
- 数据产品面试准备
- tornado使用post方法
- Mybatis if test 判断数字时需要注意
- python内存机制
- 自定义标签实现分页查询1.0版本
- malloc和free(3)——malloc()申请内存得到指针,通过memcpy()拷贝数据到指针所指内存,指针没有改变,调用free()释放内存不会报错
- 每日练习|Day012
- JavaScript浮动广告
- 无监督神经机器翻译(UNSUPERVISED NEURAL MACHINE TRANSLATION)学习笔记
- 方法重载参数为null时处理方案
- Node.js学习(五):认识模板
- Linux开发环境搭建与使用——arm开发板连接终端( xshell )
- NBUT
- HDU2053Switch Game