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效率最高。