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