每个进程都有自己的内存堆栈区域吗,以及堆内存为什么要程序员自己释放
发布网友
发布时间:2022-05-15 22:42
我来回答
共1个回答
热心网友
时间:2024-02-28 15:54
第一个问题回答只有一个字“是”,建议你看一本书叫《程序员的自我修养》。
第二个问题:对SP寄存器的值进行操作而形成逻辑上的栈,而局部变量是在函数内部定义的,就是在栈上定义的,函数的调用和对栈的操作这是一个很基础的也是很重要的知识点,你把局部变量的释放理解成了一个单独的动作,事实上编译器没有对这个局部变量的空间做任何内存管理意义上的操作。只是一个简单的对SP寄存器的值的一个改变即形成了栈的恢复动作。栈一恢复了,那之前那段栈内存上的数据你肯定找不到了,但那个物理内存地址上的数据却还是原状,所以我建义你把 ”自动释放局部变量“ 这几个字改成“自动丢弃局部变量”,丢了的东西就是找不回了,你没法用了,但那东西不会凭空从地球上消失,只是从你的视野里消失了,可能别人捡到了,别人就能用得着了,就像在函数A里创建的局部变量 local_a 可能在进程的地址空间里是地址0X11,但函数A返回之后,可能主程序又要调用函数B,而在函数B里创建的局部变量 local_b 也可能就是在0X11这个地址,那么地址0X11上边的值从A函数结束到B函数开始这段时间一直没变,只是在这段时间里没有人管理它的值。而这个过程就叫释放,或叫丢弃,
对堆内存的操作实际是动态内存操作,就涉及到内存管理了,其实现在的操作系统内核对用户空间的进程这块的创建与注销都加入了内存保护,你在用户空间的程序中释不释放堆内存,系统都会在这个程序结束时做内存回收动作,但这仅限于用户空间的程序,如果是内核编程的话,就一定要严格释放掉动态分配的内存,否则造成系统内存泄漏,内存泄漏的后果就是可用内存被你人为的弄成了不可用内存,到最后导至系统无动态内存可分配,就无法加载程序。
对于你的提问,其实没有办法回答得让你理解透澈,你现在对程序的运行机制和操作系统原理基本上是一个零的认识,慢慢来吧,多看操作系统原理的书,其实用户程序都是基于操作系统编程,理解一些原理性的东西是非常重要的。追问我好困惑,现在也在看操作系统原理的书,但是基本就是看迷糊了的状态. 现在都大四了为什么还是看不懂.是我自己不适合吗
追答贵在坚持,大家都是这么过来的。关于编程的书籍不能只看一遍,要无数遍的看,第一遍可能只看懂了百分之三十,那不懂的那些就要在以后重复阅读中去理解,边看书,边动手敲代码。从程序到操作系统,再从操作系统回到程序,这两个过程就是成为程序员的必经之路,初学者先学编程,会编程了,自己做几个小项目,像选课系统,五子棋等,做完几个项目之后,你的语法会扎实起来了,这时再看一本基于某一操作系统API的编程书籍,如UNIX环境高级编程,把大多数API用一遍,这时再去看操作系统原理,看LINUX内核设计与实现,看深入理解LINUX内核等操作系统内核的书籍及内核原代码,然后再看《程序员的自我修养》,在看书的过程中一定要敲代码。相信你会成功。
每个进程都有自己的内存堆栈区域吗,以及堆内存为什么要程序员自己释放...
而这个过程就叫释放,或叫丢弃,对堆内存的操作实际是动态内存操作,就涉及到内存管理了,其实现在的操作系统内核对用户空间的进程这块的创建与注销都加入了内存保护,你在用户空间的程序中释不释放堆内存,系统都会在这个程序结束时做内存回收动作,但这仅限于用户空间的程序,如果是内核编程的话,就一定...
为什么要有堆区和栈区
2、堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。二、堆栈缓存方式区别:1、栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放;2、堆是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦...
C语言中,什么是栈,什么是堆
2、堆区(heap):一般由程序员分配释放,若程序员不释放,则可能会引起内存泄漏。注意它和数据结构中的堆是两回事,分配方式倒是类似于链表,常见的就是malloc出来的都是属于堆区,就像固定出来的区域,到free的时候才释放,有点类似全局的,静态的。
堆和堆栈的区别
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表,呵呵。3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未...
什么事堆栈,堆栈有哪些运算,堆栈怎样存储
平常所说的,局部变量就是在堆栈中分配的.所以他出了作用域就自动释放了.c语言很容易理解,不容易出错.但c++中,编译器有不同的策略.比如 CTeacher t= bar();-- CTeacher bar(){ CTeacher xx;为CTeacher的成员赋值 return xx.} 你一定为这里xx对象是局部变量,出了函数作用域,对应的内存主释放...
什么叫堆栈
栈(stack)上分配的内存系统会自动释放,它是静态分配的。运行时栈叫堆栈。栈的分配是从内存的高地址向低地址分配的,而堆则相反。由malloc或new分配的内存都是从heap上分配的内存,从heap上分配的内存必须有程序员自己释放,用free来释放,否则这块内存会一直被占用而得不到释放,就出现了“内存泄露(Memory Leak)”。
堆和栈原理
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。 3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始...
浅析栈区和堆区内存分配的区别
由于栈上的空间是自动分配自动回收的,所以栈上的数据的生存周期只是在函数的运行过程中,运行后就释放掉,不可以再访问。而堆上的数据只要程序员不释放空间,就一直可以访问到,不过缺点是一旦忘记释放会造成内存泄露。还有其他的一些区别我认为网上的朋友总结的不错这里转述一下:1.申请后系统的响应 栈...
程序设计中,堆和栈比较重要。栈存取速度大于堆,而且编译器可以修改栈大...
回答:也许你会觉得学电脑多年,依然感觉电脑这趟水很深,你会遇到很多问题,这就需要你自己去克服了,慢慢来,相信你会成为电脑高手的。 我觉得x86上面的堆栈内存,主栈是由SS和SP访问,在32位保护模式下,SS登记是一段选择器选择器是一个数字,通过IDT(局部描述符表)或GDT(全局描述符表)选择一个段描述符...
什么是“堆”,"栈","堆栈","队列",它们的区别
②堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。2.堆栈缓存方式 ①栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。②堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿...