[记录]stack(栈)和heap(堆)的不同

来源:互联网 发布:浙大软件学院研究生 编辑:程序博客网 时间:2024/03/29 13:40


程序运行的时候,需要内存空间存放数据。一般来说,系统会划分出两种不同的内存空间:一种叫做stack(栈),另一种叫做heap(堆)。
区别:stack是有结构的,每个区块按照一定次序存放,可以明确知道每个区块的大小(先入后出);heap是没有结构的,数据可以任意存放。因此,stack的寻址速度要快于heap。

每个线程分配一个stack,每个进程分配一个heap。
stack是线程独占的,heap是线程共用的。
此外,stack创建的时候,大小是确定的,数据超过这个大小,就发生stack overflow错误,而heap的大小是不确定的,需要的话可以不断增加。
根据上面这些区别,数据存放的规则是:只要是局部的、占用空间确定的数据,一般都存放在stack里面,否则就放在heap里面。
譬如,子程序中对实例的引用是存放在stack中的,但是真正的实例(大小不确定)是存放在heap中的。

子程序运行结束,清空stack, 而heap则须等到系统的垃圾清理机制(garbage collector)将这块内存回收。

[进程和线程]
(1)一个程序至少有一个进程,一个进程至少有一个线程.
(2)进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率
(3)进程是程序的一次执行,线程是CPU的基本调度单位,cpu一次只能执行一个线程(当然多核的有几核就能同时执行几个线程)
(4)进程是一个容器,线程是容器中的工作单位。
(5)进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(174) | 评论(0) | 转发(0) |
0

上一篇:linux命令源码的查看

下一篇:没有了

相关热门文章
  • 关于SSI
  • IP Sec VPN与NAT破镜重圆
  • JS模拟鼠标自动点击
  • UT2.0正式版下载
  • tomcat6.0配置(含配置视频下载...
  • linux dhcp peizhi roc
  • 关于Unix文件的软链接
  • 求教这个命令什么意思,我是新...
  • sed -e "/grep/d" 是什么意思...
  • 谁能够帮我解决LINUX 2.6 10...
给主人留下些什么吧!~~
原创粉丝点击