#include <stdio.h>
#include <stdlib.h> //malloc free
#include <windows.h> //sleep
void main1(){
//int a[1024*1024*1000]; //数组只能处理小数量的数据
int num =100;
//int b[num]; 数组的大小必须明确,num是变量,随时可以变化
//数组内存这种分配机制就称为静态分配,数组使用完成后系统自动回收 //动态内存分配
/* malloc和free是C标准库中提供的两个函数,用以动态申请和释放内存,malloc()函数的基本调用格式为:
void *malloc( unsigned int size );
参数size是个无符号整型数,用户由此控制申请内存的大小,执行成功时,系统会为程序开辟一块大小为size个内存字节的区域,并将该区域的首地址返回,
用户可利用该地址管理并使用该块内存,如果申请失败(比如内存大小不够用),返回空指针NULL。
malloc()函数返回类型是void*,用其返回值对其他类型指针赋值时,必须进行显式转换。
size仅仅是申请字节的大小,并不管申请的内存块中存储的数据类型,因此,申请内存的长度须由程序员通过“长度×sizeof(类型)”的方式给出,举例来说:
int* p=(int*) malloc(5* sizeof(int) );
Free就是释放内存,例如free(p)
*/
//输入一个数字,并用float类型的数据初始化,形式:1.000,2.000 ... f
float f;
scanf("%f",&f);
void *pVoid = malloc(f * sizeof(float)); //malloc返回值是空指针
float *pFloat = (float *)pVoid;
//下标法
for (int i = 0; i < f; ++i) {
pFloat[i] =i+1;
printf("%f,%p \n",pFloat[i],&pFloat[i]);
}
//指针法
printf("\n\n\n");
float *p =pFloat;
int fInt = (int)f;
for ( int i = 0; p < pFloat + fInt; ++i,++p) {
// p < pFloat + fInt此处的条件要注意,既然循环了,就要用p去循环, PFloat是不变的,切忌写成 p < p + fInt,这样的话 < 两边的p就一起动了
*p = i+1;
printf("%f,%p \n",*p,p);
}
free(pVoid); //释放内存 pVoid是地址,只能free一次, NUll指针可以释放多次
}
void main2(){
float f =3.0f;
int a =(int) f;
printf("%d,%f",a,a); //3,0.000000 一个很小的整数,按照%f来解析,会打印出 0.0000000
} ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void main4(){
int n;
scanf("%d",&n);
//double *pDouble = (double *)malloc(n * sizeof(double)); //malloc不会初始化
double *pDouble = (double *)calloc(n, sizeof(double)); //calloc自动初始化内存为0
for (double i = 0.0; i < n; ++i) {
pDouble[(int)i] =i+1.0; //i 强制转换成int
printf("%lf,%p\n",pDouble[(int)i],&pDouble[(int)i]); }
} void main5(){
int num;
printf("please input the size of array:\n");
scanf("%d",&num);
int *p = (int *)malloc(num * sizeof(int));
if(p==NULL) /*防错处理,看内存申请是否成功*/
{
printf("内存申请失败,退出");
return;
}
for (int i = 0; i < num; ++i) {
p[i] =i+1;
printf("%d,%p\n",p[i],&p[i]);
} printf("if you want to rezize the array, please input a new number:\n");
int newNum;
scanf("%d",&newNum);
//为已经分配的内存重新分配空间并复制内容
// realloc()函数有两个参数:已分配的内存地址,重新分配的字节数
// void *realloc( void *ptr, size_t size )
int *newP = (int *) realloc((void *)p,newNum);
//重新分配newNum字节的内存,并根据p的地址把原来malloc分配的内容复制过来
printf("after realloc, p :%d,%p\n",*p,p); // p :1,00030E58
printf("after realloc, p+5 :%d,%p\n",*(p+5),p+5); // after realloc, p+5 :13643,006D0E6C
//似乎realloc后,没有自动释放掉p,但p的地址不变,只是所指向的类型为空指针 for (int i = num; i < newNum; ++i) { //注意因为前num个元素已经有realloc复制过来了,所以从num开始复制
newP[i] =i+1;
}
//打印新的分配的数组
for (int j = 0; j < newNum; ++j) {
printf("%d,%p\n",newP[j],&newP[j]);
}
free(p); //内存释放以后,指针的值(地址)不会变化,只是把类型取消了
free(newP);
} /*
please input the size of array:
3
1,00020E58
2,00020E5C
3,00020E60
if you want to rezize the array, please input a new number:
6
1,00020E58 可以看到新分配的内存空间首地址是一样的,可以得知旧的p指针所指向的那片内存空间后面任有剩余未占用的空间,所以继续往后分配
2,00020E5C 如果旧指针p后面没有剩余空间了,就会另外找一片内存区域,重新分配,旧的空间就自动释放掉
3,00020E60
4,00020E64
5,00020E68
6,00020E6C*/ void main(){
int num;
printf("please input the size of array:\n");
scanf("%d",&num);
int *p = (int *)malloc(num * sizeof(int));
if(p==NULL) /*防错处理,看内存申请是否成功*/
{
printf("内存申请失败,退出");
return;
} else{
for (int i = 0; i < num; ++i) {
p[i] = i + 1;
printf("%d,%p\n", p[i], &p[i]);
}
printf(" before free :%p\n",p);
free(p); //free 前后p的地址不会发生改变
printf("after free :%p\n",p);
p=NULL; //软件工程规范,释放指针后要置为NULL,可以规避释放后再次引用和反复释放的问题
printf("after free p[2]:%d\n",p[2]); //free之后,再次引用p[2]会出现垃圾数据,会报错 } }

malloc函数动态分配内存的更多相关文章

  1. malloc函数分配内存失败的常见原因

    malloc()函数分配内存失败的常见原因:  1. 内存不足.  2. 在前面的程序中出现了内存的越界访问,导致malloc()分配函数所涉及的一些信息被破坏.下次再使用malloc()函数申请内存 ...

  2. 在内存充足时malloc函数分配内存失败的原因及解决

    昨天在修改自己的代码的时候,碰到了malloc函数内存分配失败,上网翻了翻,一个很可能的原因是之前的代码出现了越界操作,导致malloc分配函数所涉及的一些信息被破坏.在这个思想的指导下,今天又是郁闷 ...

  3. 关于malloc函数的动态分配问题

    malloc函数动态分配了一个整型的内存空间,让abc都指向刚申请的空间,所以只有最后一个赋值语句的值保留在了空间里 #include<stdio.h> main() { int *a,* ...

  4. sizeof运算符、malloc函数及free函数

    一.sizeof运算符的用法 1.sizeof运算符给出某个类型或变量在内存中所占据的字节数. int a;  sizeof(a)=4;  //sizeof(int)=4; double b;  si ...

  5. C Primer Plus--C存储类、链接和内存管理之动态分配内存及类型限定词

    目录 存储类说明符 存储类和函数 动态分配内存 malloc函数 free函数 calloc函数 动态分配内存的缺点 C类型限定关键字 constant定义全局常量 volatile关键字 restr ...

  6. C++ malloc()函数的注意点及使用示例

    1.malloc()函数的头文件是stdlib.h,其函数声明如下: void* malloc(size_t size); 其中参数size_t size表示动态内存分配空间的大小,以字节为单位. s ...

  7. malloc函数

    C语言中,使用malloc函数向内存中动态申请空间. 函数的原型是extern void *malloc(unsigned int num_bytes); 可见,函数返回的是指针类型,参数是要申请的空 ...

  8. 使用malloc和free函数进行内存动态分配

    一.在学习c语言里面,内存分配这个话题非常有意思,因为我们平时在开发的时候,如果一不小心没注意内存释放的话,写的的程序很容易出错,所以今天就来回顾一下c语言里面的内存动态分配,下面我们先来看一个实例来 ...

  9. C语言malloc()函数:动态分配内存空间

    头文件:#include <stdlib.h> malloc() 函数用来动态地分配内存空间(如果你不了解动态内存分配,请查看:C语言动态内存分配及变量存储类别),其原型为:void* m ...

随机推荐

  1. ELK学习004:Elasticsearch常规操作

    CRUD 在我们的项目中有日志是一个必不可少的东西,但是日志的检索是一个很麻烦的事情,如每天一个日志,要找到问题就得一个一个找,并不能做到检索功能,这还算好的,如果是分布式的,每个机器都得找一遍,这种 ...

  2. 原创:mysql5 还原至mysql 8.0.11数据库链接配置提示错误(修改内容有三处

    原创:mysql5 还原至mysql 8.0.11数据库链接配置提示错误改有三: a) mysql 连接jar包版修改 b)类路径修改 c)配置连接池地址修改 因版本升级,首先要修改 1:mysql- ...

  3. css的核心原理分为优先级原则与继承原则两大部分

    css原理:1.优先原则=>后解析的内容会覆盖之前解析的内容(所谓解析就是读取的css样式)2.继承原则=>嵌套里面的标签拥有外部标签的某些样式,子元素可以继承父元素的属性 1>优先 ...

  4. Mac 下如何快速重启 Dock 栏?

    两种方法. 如果Dock栏出现了问题或是没有反应,请打开Launchpad并按下Command+D键. 这样就可以关闭Dock栏并重启它,效果和经常用到的killall Dock命令相同.

  5. P1028 数的计算( 记忆剪枝 )

    题目描述 我们要求找出具有下列性质数的个数(包含输入的自然数 n ): 先输入一个自然数 n(n≤1000),然后对此自然数按照如下方法进行处理: 不作任何处理; 在它的左边加上一个自然数,但该自然数 ...

  6. VSCode(主进程)

    Overview(总览) SETUP(设定) Overview(总览) Linux(略) macOS(略) Windows 使用WSL,您可以在Windows上安装和运行Linux发行版.这使您能够在 ...

  7. Mac IDEA 2019.3.1下载及破解,可激活至2089年

    背景 目前IDEA已更新到2019.3.3,但是下载这个版本后使用目前网上的常见破解方法会出现各种问题.比如使用注册码方式提示license key is in legacy format,或者使用L ...

  8. C. Long Beautiful Integer

    题目思路还是很直接,首先按要求生成字符串.如果该目标字符串小于原字符串,那么从第k位开始,找到最后一个非9的位置,++,同时如果有9,要考虑进位(一开始没有考虑WA了一次). 犯了一个错误,就是比较字 ...

  9. 清北学堂—2020.1提高储备营—Day 1 afternoon(二分、分治、贪心)

    qbxt Day 1 afternoon --2020.1.17 济南 主讲:李佳实 目录一览 1.二分法 2.分治 3.贪心 总知识点:基础算法 一.二分法 (1)算法分析:二分法是一种暴力枚举的优 ...

  10. NODEJS 中使用二维码 qr-image

    https://www.npmjs.com/package/qr-image npm install qr-image var qr = require('qr-image'); var code = ...