Fork me on GitHub

String,StringBuffer,StringBulider

StringBuffer、StringBuilder、String中都实现了CharSequence接口。

CharSequence是一个定义字符串操作的接口,它只包括length()、charAt(int index)、subSequence(int start, int end) 这几个API。

StringBuffer、StringBuilder、String对CharSequence接口的实现过程不一样.

package zhengze.ApI;
//因为有final修饰符可知道 String对象是不可变的
//将ISO8859-1字符串转成GB2312编码,语句为 : new String("ISO8859-1".getBytes("ISO8859-1"),"GB2312")

public class TestString { public static void main(String[] args) { System.out.println("Testjava.java".endsWith("java"));//b.endsWish(a)判断字符串b中的尾部是不是a //byte[] b = "中文".getBytes(); byte[] b = "abc中文".getBytes(); /* for(byte tmp : b) { System.out.println(tmp); }*/ System.out.println(new String(b)); System.out.println("s.java".matches("[a-z].java"));// 告知此字符串是否匹配给定的正则表达式。 System.out.println("12ab3ds56s".replaceAll("\\d+", "="));//使用给定的 replacement // 替换此字符串所有匹配给定的正则表达式的子字符串。 String[] ss = "172.0.18.118".split("[.]");//根据给定正则表达式的匹配拆分此字符串。 for(String tmp : ss) { System.out.println(tmp); } System.out.println("---------"); System.out.println("123456".substring(1)); //返回一个新的字符串,它是此字符串的一个子字符串。 System.out.println("123456".substring(2, 5)); //从2-5返回它是此字符串的一个子字符串。 System.out.println(" ab a ".trim() + "444"); //去返回字符串的副本,忽略前导空白和尾部空白。(半角) String s1 = "abcd"; String s2 = "abcd";//String pool System.out.println(s1 == s2); String s3 = "a" + "bcd"; System.out.println(s1 == s3); String s4 = new String("abcd");//创建新对象 地址不同 System.out.println(s1 == s4); } }

  

package zhengze.ApI;

public class Stringbuffer {
	/*
	 * StringBuffer 线程安全。 一般情况下,速度从快到慢为 StringBuilder > StringBuffer > String,
	 * 当然这是相对的,不是绝对的。
	 * 具有构造方法进行初始化。 SringBuffer对象的每次修改都会改变对象自身,这点是和String类最大的区别。
	 * StringBuffer类中的方法主要偏重于对于字符串的变化,
	 * 例如追加、插入和删除等,这个也是StringBuffer和String类的主要区别。 
	 * 使用环境: 操作少量的数据使用 String;
	 * 单线程操作大量数据使用 StringBuilder; 多线程操作大量数据使用 StringBuffer。
	 */
	public static void main(String[] args) {
		StringBuffer s = new StringBuffer();// 默认长度为16的字符串缓冲区
		StringBuffer s1 = new StringBuffer(10);// 提供一个长度为10的字符串缓冲区
		StringBuffer s2 = new StringBuffer("javadoc");
		s.append("hello").append("\t").append("world").append("\t").append("java");
		// s.insert(0, "jack:");
		// s.delete(0, 5);
		// s.deleteCharAt(4);
		// String a=s.toString();
		// String a=s.substring(0, 5);
		// System.out.println(s.toString());
		s.reverse();// 内容反转
		s.trimToSize();
		System.out.println(s);
		s1.append("1000").append("ahahahhah").append("dsdsdasdasd");
		System.out.println(s1);
		System.out.println(s1.length());// 返回的是实际长度
	}

}

  

package zhengze.ApI;

public class TestStringBuilder {
/*StringBuilder类和StringBuffer类功能基本相似,方法也差不多,
 * 主要区别在于StringBuffer类的方法是多线程安全的,
 * 而StringBuilder不是线程安全的,
 * 相比而言,StringBuilder类会略微快一点。
 * */
	
		 public static void main(String[] args) {
			    StringBuilder sb = new StringBuilder();
			    sb.append(true).append(3.14);
			    System.out.println(sb);
			    StringBuilder sb1 = sb.replace(0,2,"*");
			    //用给定 String 中的字符替换此序列的子字符串中的字符
			    //start - 起始索引(包含)。 end - 结束索引(不包含)。
			    System.out.println(sb1);
			    System.out.println(sb);
			    System.out.println(sb == sb1);
			    
			    String s = "abbc";
			    String s1 = s.replace('b', 'a');
			    System.out.println(s);
			    System.out.println(s1);
			  }

	

}

 以下转自链接:https://www.nowcoder.com/questionTerminal/abbd386334344d9c8df4a0ac918d3e0f

String, StringBuffer,StringBuilder的区别

java中String、StringBuffer、StringBuilder是编程中经常使用的字符串类,他们之间的区别也是经常在面试中会问到的问题。现在总结一下,看看他们的不同与相同。

1.可变与不可变

String类中使用字符数组保存字符串,如下就是,因为有“final”修饰符,所以可以知道string对象是不可变的。

private final char value[];

      String 为不可变对象,一旦被创建,就不能修改它的值. . 对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去.

StringBuilder与StringBuffer都继承自AbstractStringBuilder类,在AbstractStringBuilder中也是使用字符数组保存字符串,如下就是,可知这两种对象都是可变的。

char[] value;

     StringBuffer:是一个可变对象,当对他进行修改的时候不会像String那样重新建立对象 , 它只能通过构造函数来建立,  如: StringBuffer sb = new StringBuffer();

不能通过赋值符号对他进行付值. sb = "welcome to here!";//error
对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向StringBuffer中赋值的时候可以通过它的append方法.      sb.append("hello");

2.是否多线程安全

String中的对象是不可变的,也就可以理解为常量, 显然线程安全

AbstractStringBuilder是StringBuilder与StringBuffer的公共父类,定义了一些字符串的基本操作,如expandCapacity、append、insert、indexOf等公共方法。

StringBuffer对方法加了同步锁或者对调用的方法加了同步锁,所以是 线程安全的 。看如下源码:

 

1   public   synchronized  StringBuffer reverse() {

2       super .reverse();

3       return   this ;

4  }

5  

6   public   int  indexOf(String str) {

7       return  indexOf(str, 0);         //存在 public synchronized int indexOf(String str, int fromIndex) 方法

8  }

 

StringBuilder并没有对方法进行加同步锁,所以是 非线程安全的

 3.StringBuilder与StringBuffer共同点

StringBuilder与StringBuffer有公共父类AbstractStringBuilder( 抽象类 )。

抽象类与接口的其中一个区别是:抽象类中可以定义一些子类的公共方法,子类只需要增加新的功能,不需要重复写已经存在的方法;而接口中只是对方法的申明和常量的定义。

StringBuilder、StringBuffer的方法都会调用AbstractStringBuilder中的公共方法,如super.append(...)。只是StringBuffer会在方法上加synchronized关键字,进行同步。

最后,如果程序不是多线程的,那么使用StringBuilder效率高于StringBuffer。

 

效率比较String < StringBuffer < StringBuilder,但是在String S1 =“This is only a”+“simple”+“test”时,String效率最高。

posted @ 2018-09-07 14:56  雪人奥特曼  阅读(236)  评论(0编辑  收藏  举报