栈内存:
栈内存在函数中定义的一些 基本类型的变量 和 对象的引用变量 都在函数的栈内存中分配。当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用。
栈的优势是, 存取速度比堆要快 ,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。 栈中主要存放一些基本类型的变量(,int, short, long, byte, float, double, boolean, char)和对象句柄 。栈有一个很重要的特殊性,就是存在栈中的数据可以共享。
堆内存:
堆内存是区别于栈区、全局数据区和代码区的另一个内存区域。堆允许程序在运行时 动态地申请某个大小的内存空间 。
区别:
堆内存和栈内存的区别可以用如下的比喻来看出:使用堆内存就象是自己动手做喜欢吃的菜肴,比较麻烦,你的洗菜,切菜,炒菜,还要洗碗,倒垃圾(销毁对象)等,但是比较符合自己的口味,而且 自由度 大。
使用栈内存就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。
操作系统中所说的堆内存和 栈内存 ,在操作上有上述的特点,这里的堆内存实际上指的就是(满足堆内存性质的) 优先队列 的一种数据结构,第1个元素有最高的 优先权 ;栈内存实际上就是满足先进后出的性质的数学或数据结构。
简单来说,值类型是分配在栈里面,引用类型分配在堆里面。
那从内存的分配角度来看,是因为值类型,已经知道了类型的范围大小,可以进行有效分配,比如int,计算机是知道其范围的,所以直接由系统分配在栈中,无需自己申请!而新的类型,比如自己定义一个类,很明显这个类是不知道大小的,应该有程序自己来申请内存空间,所以由堆来分配!一张图胜过千言万语:
栈内存在函数中定义的一些 基本类型的变量 和 对象的引用变量 都在函数的栈内存中分配。当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用。
栈的优势是, 存取速度比堆要快 ,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。 栈中主要存放一些基本类型的变量(,int, short, long, byte, float, double, boolean, char)和对象句柄 。栈有一个很重要的特殊性,就是存在栈中的数据可以共享。
堆内存:
堆内存是区别于栈区、全局数据区和代码区的另一个内存区域。堆允许程序在运行时 动态地申请某个大小的内存空间 。
区别:
堆内存和栈内存的区别可以用如下的比喻来看出:使用堆内存就象是自己动手做喜欢吃的菜肴,比较麻烦,你的洗菜,切菜,炒菜,还要洗碗,倒垃圾(销毁对象)等,但是比较符合自己的口味,而且 自由度 大。
使用栈内存就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。
操作系统中所说的堆内存和 栈内存 ,在操作上有上述的特点,这里的堆内存实际上指的就是(满足堆内存性质的) 优先队列 的一种数据结构,第1个元素有最高的 优先权 ;栈内存实际上就是满足先进后出的性质的数学或数据结构。
简单来说,值类型是分配在栈里面,引用类型分配在堆里面。
那从内存的分配角度来看,是因为值类型,已经知道了类型的范围大小,可以进行有效分配,比如int,计算机是知道其范围的,所以直接由系统分配在栈中,无需自己申请!而新的类型,比如自己定义一个类,很明显这个类是不知道大小的,应该有程序自己来申请内存空间,所以由堆来分配!一张图胜过千言万语: