这里主要分享几个链接:
栈,堆,方法区http://www.cnblogs.com/kkcheng/archive/2011/02/25/1964521.html
内存管理http://www.cnblogs.com/gw811/archive/2012/10/18/2730117.html
垃圾收集器http://www.cnblogs.com/gw811/archive/2012/10/19/2730258.html
下面是自己目前不能忘记的皮毛
堆区:
1.存储的全部是对象,每个对象都包含一个与之对应的class的信息。(class的目的是得到操作指令)
2.jvm只有一个堆区(heap)被所有线程共享,堆中不存放基本类型和对象引用,只存放对象本身
栈区:
1.每个线程包含一个栈区,栈中只保存基础数据类型的对象和自定义对象的引用(不是对象),对象都存放在堆区中
2.每个栈中的数据(原始类型和对象引用)都是私有的,其他栈不能访问。
3.栈分为3个部分:基本类型变量区、执行环境上下文、操作指令区(存放操作指令)。
方法区:
1.又叫静态区,跟堆一样,被所有的线程共享。方法区包含所有的class和static变量。
2.方法区中包含的都是在整个程序中永远唯一的元素,如class,static变量。
还有对于字符串的理解,String类型并不是JAVA的基本数据类型(JAVA八种基础数据类型,参看http://www.cnblogs.com/simplefrog/archive/2012/07/15/2592011.html),所以new String()的对象其实是存放在堆区的。先放着我们接着看。
String s1="This is String";
String s2="This is String";
System.out.println(s1==s2);输出true。
String s3=new String("This is String");
System.out.println(s1==s3);输出false。
为什么呢?s1==s2这一类比较的是引用的对象(在JAVA里面s1.equals(s2)比较的是引用的内容都为true)。
String s1="This is String"得到的是来自堆中的字符串的引用,当String s2="This is String"执行时发现栈里面已经存在了该字符串的引用(String类是常量类,参看http://blog.csdn.net/qq_38584967/article/details/78385655),那么就会把栈中这个字符串的引用赋予s2,这样一来s1和s2就变成了对同一个对象的引用了,于是s1==s2返回true。
再看s3,上面说了String不是基本数据类型,所以String s3=new String("This is String")是直接得到的是一个在堆中新建的对象的引用,虽然它的内容和s1引用的内容是一样的,但内存并不是同一块,于是比较栈中两个引用s1==s3返回的是false,因为引用的对象不同。
哈哈,自己的以为,所以可能有些偏差,若是有人看到这篇博客了,有不对或疑问的请及时留言指正。互相学习,谢谢!