在使用StringBuffer 的时候,习惯性的像String一样把他初始化为了
  StringBuffer result = null;
  结果警告:Null pointer access: The variable result can only be null at this location
  运行后报错,才意识到StringBuffer和String还是有很多区别的,摆渡了些资料整理出来,共享。
  以下部分转载自http://www.cnblogs.com/springcsc/archive/2009/12/03/1616330.html
  StringBuffer类和String一样,也用来代表字符串,只是由于StringBuffer的内部实现方式和String不同,所以StringBuffer在进行字符串处理时,不生成新的对象,在内存使用上要优于String类。
  所以在实际使用时,如果经常需要对一个字符串进行修改,例如插入、删除等操作,使用StringBuffer要更加适合一些。
  在StringBuffer类中存在很多和String类一样的方法,这些方法在功能上和String类中的功能是完全一样的。
  但是有一个显著的区别在于,对于StringBuffer对象的每次修改都会改变对象自身,这点是和String类大的区别。
  另外由于StringBuffer是线程安全的,关于线程的概念后续有专门的章节进行介绍,所以在多线程程序中也可以很方便的进行使用,但是程序的执行效率相对来说要稍微慢一些。
  1、StringBuffer对象的初始化
  StringBuffer对象的初始化不像String类的初始化一样,Java提供的有特殊的语法,而通常情况下一般使用构造方法进行初始化。
  例如:
  StringBuffer s = new StringBuffer();
  这样初始化出的StringBuffer对象是一个空的对象,是我犯的错误。
  如果需要创建带有内容的StringBuffer对象,则可以使用:
  StringBuffer s = new StringBuffer(“abc”);
  这样初始化出的StringBuffer对象的内容是字符串”abc”。
  需要注意的是,StringBuffer和String属于不同的类型,也不能直接进行强制类型转换,下面的代码都是错误的:
  StringBuffer s = “abc”;               //赋值类型不匹配
  StringBuffer s = (StringBuffer)”abc”;    //不存在继承关系,无法进行强转
  StringBuffer对象和String对象之间的互转的代码如下:
  String s = “abc”;
  StringBuffer sb1 = new StringBuffer(“123”);
  StringBuffer sb2 = new StringBuffer(s);   //String转换为StringBuffer
  String s1 = sb1.toString();              //StringBuffer转换为String
  2、StringBuffer的常用方法
  StringBuffer类中的方法主要偏重于对于字符串的变化,例如追加、插入和删除等,这个也是StringBuffer和String类的主要区别。
  a、append方法
  public StringBuffer append(boolean b)
  该方法的作用是追加内容到当前StringBuffer对象的末尾,类似于字符串的连接。调用该方法以后,StringBuffer对象的内容也发生改变,例如:
  StringBuffer sb = new StringBuffer(“abc”);
  sb.append(true);
  则对象sb的值将变成”abctrue”。
  使用该方法进行字符串的连接,将比String更加节约内容,例如应用于数据库SQL语句的连接,例如:
  StringBuffer sb = new StringBuffer();
  String user = “test”;
  String pwd = “123”;
  sb.append(“select * from userInfo where username=“)
  .append(user)
  .append(“ and pwd=”)
  .append(pwd);
  这样对象sb的值是字符串“select * from userInfo where username=test and pwd=123”。