在这里malloc()函数的返回值是一个指针,或者说是分配后内存空间的首地址
如果malloc()函数申请空间成功则返回一段内存空间的首地址,失败则返回NULL
2、int *p;
p = malloc(sizeof(int));
在这里是不能这样写的,会出现错误:从类型 ‘void*’ 到类型‘int’的转换无效,应该改为:
p =(int *) malloc(sizeof(int));
3、在使用malloc()函数申请的空间之前,最好用memset()函数把这段内存空间清理一下,因为用malloc()函数申请的空间仅仅保证的是内存空间的大小,并不保证内存空间是否有数据垃圾
4、当不在使用malloc()函数申请的空间之后,应该使用如下函数释放掉这个内存空间:
void free(void *ptr);
其中void *ptr是malloc()函数的返回值,也就是内存空间的首地址
如果只知道使用,而不知道释放,则在7天*24小时运行的嵌入式产品中,很容易会出现内存泄漏,最终导致系统瘫痪
样例代码:
#include
#include
#include
#include
#include
#include
#include<stdlib.h>
using namespace std;
int main()
{
int * ptr;
ptr=(int *)malloc(sizeof(int));
if(ptr==NULL)
cout<<“false”<<endl;
cout<<“please input a int”<<endl;
cin>>*ptr;
cout
<<“the int is:”<<endl;
cout<<*ptr<<endl;
return 0;
}
// 输出
please input a int
520
the int is:
520
the int is:
520
Process returned 0 (0x0) execution time : 3.301 s
Press any key to continue.
free:
看到上面的代码,小飞明明使用了free去释放ptr但是调用它后还是会输出520;这是为什么呢?,好下面就来解释一下。
free(pointer); 释放的是指针指向的内存。注意,释放的是内存,不是指针。指针并没有被释放,指针仍然指向原来的存储空间。指针是一个变量,只有程序结束时才被销毁。释放了内存空间后,原来指向这块空间的指针还是存在,只不过现在指针指向的内容是垃圾,是未定义的。因此,释放内存后把指针指向 NULL,防止指针在后面不小心又被解引用了。
free函数仅仅是将malloc申请的内存释放回去,所谓的释放也就是告诉编译器,这块内存已经使用完毕,可以收回了。但指针所指向的内存值,并不会发生改变。就可以比方说,你租了一套房子,到期后,房子收回归还房东,而此时你可能还拿着房子的钥匙,这个时候你虽然可以继续访问这个房子(内存),但已经不属于你,是非法的。也可能有新的租客入驻更改房子的内置,也可能还是这个样子。取决于不同的房东(编译器)和租客(内容)。
关于free的函数的具体使用我就直接上链接了;
free函数的使用
最后
小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
如果你需要这些资料, ⬅ 专栏获取
义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
如果你需要这些资料, ⬅ 专栏获取