当前位置:   article > 正文

C以及C++的内存管理分析以及比较_c++中如何进行内存地址的比较运算

c++中如何进行内存地址的比较运算

C/C++内存分布

首先看下面这个代码

int a= 1;
void test()
{
   
	static int b = 2;
	char num[] = "123";
	int* p = (int*)mallocsizeof(int)* 4);
	char* ptr = "abcd";
} 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

对于C语言的学习,我们不难看出,a,b在数据段,num,*p,*ptr在栈,p在堆上,ptr在代码段。因此,可以做如下总结。
1. 栈又叫堆栈,非静态局部变量/函数参数/返回值等等,栈是向下增长的。
2. 内存映射段是高效的I/O映射方式,用于装载一个共享的动态内存库。用户可使用系统接口创建共享共 享内存,做进程间通信。
3. 堆用于程序运行时动态内存分配,堆是可以上增长的。
4. 数据段–存储全局数据和静态数据。
5. 代码段–可执行的代码/只读常量

在C语言中,常用的内存管理函数malloc,realloc,calloc
malloc:只进行空间申请,不进行初始化
realloc调整空间大小
1. 直接原地调整大小。
2. 重新开空间: 重新申请空间,内容拷贝,释放原有空间
calloc:空间申请并且初始化
当然用上述三个函数,都需要用free释放空间,否

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/641071
推荐阅读
相关标签
  

闽ICP备14008679号