2019年09月18日(星期三)  农历:己亥年八月二十
  • 首页
  • JAVA
  • java知识:关于String和StringBuffer

作者:三年。分类: JAVA 标签: java java基础 String StringBuffer 关于String和StringBuffer

JAVA语言供给了关于String类型变量的操作。但如果使用不当,会给程序的功能带来影响。如下面的语句:
String name=new String("LaiLiKun");
System.out.println(name+"is my name");
看似现已很精简了,其实并非如此。为了生成二进制的代码,要进行如下的过程和操作:
(1) 生成新的字符串 new String(STR_1);
(2) 仿制该字符串;
(3) 加载字符串常量"HuangWeiFeng"(STR_2);
(4) 调用字符串的构架器(Constructor);
(5) 保留该字符串到数组中(从方位0开端);
(6) 从java.io.PrintStream类中得到静态的out变量;
(7) 生成新的字符串缓冲变量new StringBuffer(STR_BUF_1);
(8) 仿制该字符串缓冲变量;
(9) 调用字符串缓冲的构架器(Constructor);
(10) 保留该字符串缓冲到数组中(从方位1开端);
(11) 以STR_1为参数,调用字符串缓冲(StringBuffer)类中的append办法;
(12) 加载字符串常量"is my name"(STR_3);
(13) 以STR_3为参数,调用字符串缓冲(StringBuffer)类中的append办法;
(14) 关于STR_BUF_1履行toString指令;
(15) 调用out变量中的println办法,输出成果。
由此可以看出,这两行简略的代码,就生成了STR_1,STR_2,STR_3,STR_4和STR_BUF_1五个目标变量。这些生成的类的实例通常 都存放在堆中。堆要对一切类的超类,类的实例进行初始化,一起还要调用类极端每个超类的构架器。而这些操作都是非常消耗体系资源的。因而,对目标的生成进 行约束,是彻底有必要的。
经修正,上面的代码可以用如下的代码来更换。
StringBuffer name=new StringBuffer("LaiLiKun");
System.out.println(name.append("is my name.").toString());
体系将进行如下的操作:
(1) 生成新的字符串缓冲变量new StringBuffer(STR_BUF_1);
(2) 仿制该字符串缓冲变量;
(3) 加载字符串常量"HuangWeiFeng"(STR_1);
(4) 调用字符串缓冲的构架器(Constructor);
(5) 保留该字符串缓冲到数组中(从方位1开端);
(6) 从java.io.PrintStream类中得到静态的out变量;
(7) 加载STR_BUF_1;
(8) 加载字符串常量"is my name"(STR_2);
(9) 以STR_2为参数,调用字符串缓冲(StringBuffer)实例中的append办法;
(10) 关于STR_BUF_1履行toString指令(STR_3);
(11)调用out变量中的println办法,输出成果。
由此可以看出,经过改善后的代码只生成了四个目标变量:STR_1,STR_2,STR_3和STR_BUF_1.你也许觉得少生成一个目标不会对程序 的功能有很大的进步。但下面的代码段2的履行速度将是代码段1的2倍。由于代码段1生成了八个目标,而代码段2只生成了四个目标。
代码段1:
String name= new StringBuffer("LaiLiKun");
name+="is my";
name+="name";
代码段2:
StringBuffer name=new StringBuffer("LaiLiKun");
name.append("is my");

name.append("name.").toString();


温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!

已有 0/3134 人参与

发表评论:



手Q扫描加入Java初学者群