java字符串(String)
来源:互联网 发布:软件项目风险评估报告 编辑:程序博客网 时间:2024/06/09 20:01
String 是java.lang包下的一个类,按照标准的面向对象的语法,其格式应该为:
String stringName = new String(“string content”);
例如:
String url = new String(“http://www.csdn.net/”);
但是由于String特别常用,所以Java提供了一种简化的语法。
使用简化语法的另外一个原因是,按照标准的面向对象的语法,在内存使用上存在比较大的浪费。例如String str = new String(“abc”);实际上创建了两个String对象,一个是”abc”对象,存储在常量空间中,一个是使用new关键字为对象str申请的空间。
String对象常规方法
1) length() 方法
String str1 = “真凌胜”;
String str2 = “csdn”;
System.out.println(“The lenght of str1 is ” + str1.length());
System.out.println(“The lenght of str2 is ” + str2.length());
输出结果:
The lenght of str1 is 3
The lenght of str2 is 4
可见,无论是字母、数字,还是汉字,每个字符的长度都是1。
2) charAt() 方法
charAt() 方法的作用是按照索引值获得字符串中的指定字符。Java规定,字符串中第一个字符的索引值是0,第二个字符的索引值是1,依次类推。例如:
String str = “123456789”;
System.out.println(str.charAt(0) + ” ” + str.charAt(5) + ” ” + str.charAt(8));
输出结果:
1 6 9
3) contains() 方法
contains() 方法用来检测字符串是否包含某个子串,例如:
String str = “ Collections”;
System.out.println(str.contains(“Coll”));
输出结果:
true
4) replace() 方法
字符串替换,用来替换字符串中所有指定的子串,例如:
String str1=“百度搜索”;String str2 = str1.replace(“百度”, “搜狗”);
System.out.println(str1);
System.out.println(str2);
输出结果:
注意:replace() 方法不会改变原来的字符串,而是生成一个新的字符串。
5) split() 方法
以指定字符串作为分隔符,对当前字符串进行分割,分割的结果是一个数组,例如:
String str =“ 12345678”;String strArr[] = str.split(
"3"
);
System.out.println(Arrays.toString(strArr));
输出结果:12
StringBuffer、StringBuilder、String
String 的值是不可变的,每次对String的操作都会生成新的String对象,不仅效率低,而且耗费大量内存空间。
StringBuffer类和String类一样,也用来表示字符串,但是StringBuffer的内部实现方式和String不同,在进行字符串处理时,不生成新的对象,在内存使用上要优于String。
StringBuffer 默认分配16字节长度的缓冲区,当字符串超过该大小时,会自动增加缓冲区长度,而不是生成新的对象。
StringBuffer不像String,只能通过 new 来创建对象,不支持简写方式,例如:
StringBuffer str1 = new StringBuffer(); // 分配16个字节长度的缓冲区
StringBuffer str2 = new StringBuffer(512); // 分配512个字节长度的缓冲区
// 在缓冲区中存放了字符串,并在后面预留了16个字节长度的空缓冲区
StringBuffer str3 = new StringBuffer(“http://www.csdn.net/”);
StringBuffer类的主要方法
StringBuffer类中的方法主要偏重于对于字符串的操作,例如追加、插入和删除等,这个也是StringBuffer类和String类的主要区别。实际开发中,如果需要对一个字符串进行频繁的修改,建议使用 StringBuffer。
1) append() 方法
append() 方法用于向当前字符串的末尾追加内容,类似于字符串的连接。调用该方法以后,StringBuffer对象的内容也发生改变,例如:
StringBuffer str = new StringBuffer(“biancheng100”);
str.append(true);
则对象str的值将变成”biancheng100true”。注意是str指向的内容变了,不是str的指向变了。
字符串的”+“操作实际上也是先创建一个StringBuffer对象,然后调用append()方法将字符串片段拼接起来,最后调用toString()方法转换为字符串。
这样看来,String的连接操作就比StringBuffer多出了一些附加操作,效率上必然会打折扣。
但是,对于长度较小的字符串,”+“操作更加直观,更具可读性,有些时候可以稍微牺牲一下效率。
2) deleteCharAt()
deleteCharAt() 方法用来删除指定位置的字符,并将剩余的字符形成新的字符串。例如:
StringBuffer str = new StringBuffer(“abcdef”);
str. deleteCharAt(3);
该代码将会删除索引值为3的字符,即”d“字符。
你也可以通过delete()方法一次性删除多个字符,例如:
StringBuffer str = new StringBuffer(“abcdef”);
str.delete(1, 4);
该代码会删除索引值为1~4之间的字符,包括索引值1,但不包括4。
3) insert() 方法
insert() 用来在指定位置插入字符串,可以认为是append()的升级版。例如:
StringBuffer str = new StringBuffer(“abcdef”);
str.insert(3, “xyz”);
最后str所指向的字符串为 abcdxyzef。
4) setCharAt() 方法
setCharAt() 方法用来修改指定位置的字符。例如:
StringBuffer str = new StringBuffer(“abcdef”);
str.setCharAt(3, ‘z’);
该代码将把索引值为3的字符修改为 z,最后str所指向的字符串为 abczef。
StringBuilder类和StringBuffer类功能基本相似,方法也差不多,主要区别在于StringBuffer类的方法是多线程安全的,而StringBuilder不是线程安全的,相比而言,StringBuilder类会略微快一点。
StringBuffer、StringBuilder、String中都实现了CharSequence接口。
CharSequence是一个定义字符串操作的接口,它只包括length()、charAt(int index)、subSequence(int start, int end) 这几个API。
线程安全:
StringBuffer:线程安全
StringBuilder:线程不安全
速度:
一般情况下,速度从快到慢为 StringBuilder > StringBuffer > String,当然这是相对的,不是绝对的。
使用环境:
操作少量的数据使用 String;
单线程操作大量数据使用 StringBuilder;
多线程操作大量数据使用 StringBuffer。
- Java字符串(String)
- java 字符串(string)
- java字符串(String)
- Java — String(字符串)
- java字符串String(一)
- Java字符串String(一)
- Java 字符串(String类)
- java string pool(java 字符串池)
- java字符串String与String
- java中的字符串(String)的秘密
- Java 字符串常用操作(String类)
- Java字符串(String)分割方法
- Java字符串(String)分割方法
- Java中的字符串驻留(String Interning)
- String字符串通过MD5加密(java)
- Java——关于String(字符串)
- java的(String)字符串方法
- Java String Pool (字符串池)
- 没钱万万不能看徐翔都吃面了
- OD内存断点
- C++智能指针模板类复习
- 关于“机器学习算法”与《算法导论》中“算法”的讨论
- 201 Bitwise AND of Numbers Range
- java字符串(String)
- foreach语句使用总结
- 我要接触的东西分别是什么?
- (3870)ZOJ
- python(第一天): 工厂函数
- eclipse使用指南(持续更新)
- XDU 挖掘机 线段树求解
- 2015编程之美初赛
- 黑马程序员_IO流基本概念