java那点事——StringBuffer与StringBuilder原理与区别.docxVIP

java那点事——StringBuffer与StringBuilder原理与区别.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
java那点事——StringBuffer与StringBuilder原理与区别

在讲解String之前,我们先了解一下Java的内存结构。一、Java内存模型按照官方的说法:Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。 JVM主要管理两种类型内存:堆和非堆,堆内存(Heap?Memory)是在 Java 虚拟机启动时创建,非堆内存(Non-heap Memory)是在JVM堆之外的内存。简单来说,非堆包含方法区、JVM内部处理或优化所需的内存(如?JITCompiler,Just-in-time Compiler,即时编译后的代码缓存)、每个类结构(如运行时常数池、字段和方法数据)以及方法和构造方法的代码。?Java的堆是一个运行时数据区,类的(对象从中分配空间。这些对象通过new、newarray、 anewarray和multianewarray等指令建立,它们不需要程序代码来显式的释放。堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,Java的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要在运行时动态分配内存,存取速度较慢。? 栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。栈中主要存放一些基本类型的变量数据(int, short, long, byte, float, double, boolean, char)和对象句柄(引用)。? 虚拟机必须为每个被装载的类型维护一个常量池。常量池就是该类型所用到常量的一个有序集合,包括直接常量(string,integer和 floating point常量)和对其他类型,字段和方法的符号引用。? 对于String常量,它的值是在常量池中的。而JVM中的常量池在内存当中是以表的形式存在的, 对于String类型,有一张固定长度的CONSTANT_String_info表用来存储文字字符串值,注意:该表只存储文字字符串值,不存储符号引用。说到这里,对常量池中的字符串值的存储位置应该有一个比较明了的理解了。在程序执行的时候,常量池会储存在Method Area,而不是堆中。常量池中保存着很多String对象;?并且可以被共享使用,因此它提高了效率?具体关于JVM和内存等知识请参考:JVM 基础知识Java 内存模型及GC原理二、案例解析public?static?void?main(String[]?args)?{???/**??*?情景一:字符串池??*?JAVA虚拟机(JVM)中存在着一个字符串池,其中保存着很多String对象;??*?并且可以被共享使用,因此它提高了效率。??*?由于String类是final的,它的值一经创建就不可改变。??*?字符串池由String类维护,我们可以调用intern()方法来访问字符串池。??*/???String?s1?=?abc;?//↑?在字符串池创建了一个对象??String?s2?=?abc;?//↑?字符串pool已经存在对象“abc”(共享),所以创建0个对象,累计创建一个对象??System.out.println(s1?==?s2?:?+(s1==s2));?//↑?true?指向同一个对象,??System.out.println(s1.equals(s2)?:??+?(s1.equals(s2)));?//↑?true??值相等??//↑------------------------------------------------------over???/**??*?情景二:关于new?String()??*???*/???String?s3?=?new?String(abc);???//↑?创建了两个对象,一个存放在字符串池中,一个存在与堆区中;??//↑?还有一个对象引用s3存放在栈中??String?s4?=?new?String(abc);???//↑?字符串池中已经存在“abc”对象,所以只在堆中创建了一个对象??System.out.println(s3?==?s4?:?+(s3==s4));???//↑false???s3和s4栈区的地址不同,指向堆区的不同地址;??System.out.println(s3.equals(s4)?:?+(s3.equals(s4)));???//↑true??s3和s4的值相同??System.out.println(s1?==?s3?:?+(s1==s3));???//↑false?存放的地区多不同,一个栈区,一个堆区??System.out.println(s1.equals(s3)?:?+(s1.equals(s3)));???//↑true??值相

文档评论(0)

wnqwwy20 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档