【JAVA】字符串及StringBuffe和StringBuilder

常见字符串方法:
1.长度
2.字符串索引位置的字符
3.提取子串
4.拆分
5.合并
6.转换成字符数组
7.字符数组转换成字符串
8.把其他数据类型转换成字符串
9.替换
10.正则表达式
11.根据字符返回索引位置

这里要注意的是:
字符串全都是存到代码区的,字符串的引用实际上指向是代码区的地址,那么代码是不能改的。且字符串类型是不能继承的,也就是说,字符串就是常量。

String 方法描述
1 char charAt(int index)
返回指定索引处的 char 值。
2 int compareTo(Object o)
把这个字符串和另一个对象比较。
3 int compareTo(String anotherString)
按字典顺序比较两个字符串。
4 int compareToIgnoreCase(String str)
按字典顺序比较两个字符串,不考虑大小写。
5 String concat(String str)
将指定字符串连接到此字符串的结尾。
6 boolean contentEquals(StringBuffer sb)
当且仅当字符串与指定的StringBuffer有相同顺序的字符时候返回真。
7 static String copyValueOf(char[] data)
返回指定数组中表示该字符序列的 String。
8 static String copyValueOf(char[] data, int offset, int count)
返回指定数组中表示该字符序列的 String。
9 boolean endsWith(String suffix)
测试此字符串是否以指定的后缀结束。
10 boolean equals(Object anObject)
将此字符串与指定的对象比较。
11 boolean equalsIgnoreCase(String anotherString)
将此 String 与另一个 String 比较,不考虑大小写。
12 byte[] getBytes()
使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。
13 byte[] getBytes(String charsetName)
使用指定的字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。
14 void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
将字符从此字符串复制到目标字符数组。
15 int hashCode()
返回此字符串的哈希码。
16 int indexOf(int ch)
返回指定字符在此字符串中第一次出现处的索引。
17 int indexOf(int ch, int fromIndex)
返回在此字符串中第一次出现指定字符处的索引,从指定的索引开始搜索。
18 int indexOf(String str)
返回指定子字符串在此字符串中第一次出现处的索引。
19 int indexOf(String str, int fromIndex)
返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始。
20 String intern()
返回字符串对象的规范化表示形式。
21 int lastIndexOf(int ch)
返回指定字符在此字符串中最后一次出现处的索引。
22 int lastIndexOf(int ch, int fromIndex)
返回指定字符在此字符串中最后一次出现处的索引,从指定的索引处开始进行反向搜索。
23 int lastIndexOf(String str)
返回指定子字符串在此字符串中最右边出现处的索引。
24 int lastIndexOf(String str, int fromIndex)
返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索。
25 int length()
返回此字符串的长度。
26 boolean matches(String regex)
告知此字符串是否匹配给定的正则表达式。
27 boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)
测试两个字符串区域是否相等。
28 boolean regionMatches(int toffset, String other, int ooffset, int len)
测试两个字符串区域是否相等。
29 String replace(char oldChar, char newChar)
返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的。
30 String replaceAll(String regex, String replacement)
使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。
31 String replaceFirst(String regex, String replacement)
使用给定的 replacement 替换此字符串匹配给定的正则表达式的第一个子字符串。
32 String[] split(String regex)
根据给定正则表达式的匹配拆分此字符串。
33 String[] split(String regex, int limit)
根据匹配给定的正则表达式来拆分此字符串。
34 boolean startsWith(String prefix)
测试此字符串是否以指定的前缀开始。
35 boolean startsWith(String prefix, int toffset)
测试此字符串从指定索引开始的子字符串是否以指定前缀开始。
36 CharSequence subSequence(int beginIndex, int endIndex)
返回一个新的字符序列,它是此序列的一个子序列。
37 String substring(int beginIndex)
返回一个新的字符串,它是此字符串的一个子字符串。
38 String substring(int beginIndex, int endIndex)
返回一个新字符串,它是此字符串的一个子字符串。
39 char[] toCharArray()
将此字符串转换为一个新的字符数组。
40 String toLowerCase()
使用默认语言环境的规则将此 String 中的所有字符都转换为小写。
41 String toLowerCase(Locale locale)
使用给定 Locale 的规则将此 String 中的所有字符都转换为小写。
42 String toString()
返回此对象本身(它已经是一个字符串!)。
43 String toUpperCase()
使用默认语言环境的规则将此 String 中的所有字符都转换为大写。
44 String toUpperCase(Locale locale)
使用给定 Locale 的规则将此 String 中的所有字符都转换为大写。
45 String trim()
返回字符串的副本,忽略前导空白和尾部空白。
46 static String valueOf(primitive data type x)
返回给定data type类型x参数的字符串表示形式。


package Character_string;
//	static int aaa=20;
//	static void aab() {}
public class Character_string {
	//1.长度
	//2.字符串索引位置的字符
	//3.提取子串
	//4.拆分
	//5.合并
	//6.转换成字符数组
	//7.字符数组转换成字符串
	//8.把其他数据类型转换成字符串
	//9.替换
	//10.正则表达式
	//11.根据字符返回索引位置
	//...
	public static void main(String[] args) {
		String s="asd.fda sfsa,df2 3423,423";
		
		System.out.println(s.length());//1.
		
		
		System.out.println(s.charAt(4));
		System.out.println(s.substring(4,10));//2.
		
		
		System.out.println("***************************");
		String[] aa=s.split(" ");//3.//包括索引4的字符,不包括索引10的字符。
		
		
		for(int i=0;i<aa.length;i++) {
			System.out.print(aa[i]);
		}
		System.out.println();
		System.out.println("***************************");//4.
		
		
		System.out.println(s.concat("Hello"));
		System.out.println("***************************");
		char[] tt=s.toCharArray();
		for(int i=0;i<tt.length;i++) {
			System.out.print(tt[i]);
		}
		System.out.println();
		System.out.println("***************************");//6.
		
		
		String ss=new String(tt);
		System.out.println(ss);//7.
		
		
//		String sss=new String("adsfasdf");
		System.out.println("***************************");
		
		
		String str="We Are Happy.";
		System.out.print(str.replace("We", "You"));
		System.out.println();
		System.out.print(str.replaceAll(" ","%20"));//9.replaceAll可以替换所有
		
		System.out.println();
//		Test.aaa=22;//虽然aaa和aab()可以直接调用,
//		Test.aab();//但是推荐用类名直接去调用。
		System.out.print(String.valueOf(true));//8.
		//静态的成员最好用类名去调用。
		//加一个限定,访问起来更清晰。此处valueOf为静态方法。
		//但是此处不用加valueOf也可以输出字符串,此为装箱、拆箱的相关思想。
		
		
		System.out.println(s.indexOf('d', 3));//11.
		//判断第几个字符、字符串在哪个索引位置
		//还可以加起始索引,判断在哪个位置。
		
		
		String tttt="    fsdfdsf";
		System.out.println(tttt.toUpperCase());//13.
		System.out.println(tttt.toLowerCase());//14.
		
		
		byte[] aaaaa=tttt.getBytes();//字符数组变成字节数组
		System.out.println(new String(aaaaa));//根据此字节数组还原成了字符串
	}
}

输出结果

25
f
fda sf
***************************
asd.fdasfsa,df23423,423
***************************
asd.fda sfsa,df2 3423,423Hello
***************************
asd.fda sfsa,df2 3423,423
***************************
asd.fda sfsa,df2 3423,423
***************************
You Are Happy.
We%20Are%20Happy.
true5
    FSDFDSF
    fsdfdsf
    fsdfdsf

StringBuffer与StringBuilder

1.StringBuffer和StringBuilder是在缓存里追加完字符串之后,再调用toString方法变成字符串的。所有的对象都有toString方法,是从Object里继承下来的。StringBuffer或StringBuilder相当于是将字符串进行了重写,然后将里面追加的字符变成了字符串。

2.StringBuffer和StringBuilder不是字符串,而是数组缓存。而StriniBuilder的前身StringStringBuffer,StringBuffer的效率略微有些低,但允许采用多线程的方式执行添加或删除字符串的操作。如果所有字符串在一个单线程中(通常都是这样)编辑, 则应该用StringBuilder去替代它,这两类的API是相同的。

3.StringBuffer 和 StringBuilder 类的对象能够被多次的修改,并且不产生新的未使用对象。StringBuilder 类在 Java 5 中被提出,它和 StringBuffer 之间的最大不同在于 StringBuilder 的方法不是线程安全的(不能同步访问)。

4.由于 StringBuilder 相较于 StringBuffer 有速度优势,所以多数情况下建议使用 StringBuilder 类。然而在应用程序要求线程安全的情况下,则必须使用 StringBuffer 类。

public class Test1 {
	public static void main(String[] args) {
		String str = "Hello";
		str += "World";// 此时,尽管字符串后加了字符。
		str += "!";// 但是字符串并没有变长。
		// 因为字符串是常量,在代码区里并没有变。
		// 而在此时,是创建了新的对象,让原先的引用指向了该新对象。
		// 也就是其指向的地址变了,所以原来引用指向的对象就成了垃圾。
		// 因为系统在空闲的时候,要使用垃圾回收器。
		// 这个过程比较占内存,所以会出现卡顿。
		// 那么,像上面的连接方式就不可取了

		// 更高效的方式
		StringBuffer sb = new StringBuffer();
		StringBuilder sss = new StringBuilder();
		// 把以上的字符串对象拿出来,用append进行追加。
		sb.append("Hello");
		sb.append("World");
		sb.append("!");
		String tt = sb.toString();
		System.out.println(tt);
		System.out.println(str);
	}
}

方法链的应用

public class String_BufferTest {
	public static int lcs(char[] x, char[] y, int i, int j, int[][] bak) {
		for (int ii = 0; ii <= i; ii++) {
			for (int jj = 0; jj <= j; jj++) {
				if (ii == 0 || jj == 0) {
					bak[ii][jj] = 0;
				} else if (x[ii] == y[jj]) {
					bak[ii][jj] = bak[ii - 1][jj - 1] + 1;
				} else
					bak[ii][jj] = max(bak[ii - 1][jj], bak[ii][jj - 1]);
			}
		}

		return bak[i][j];
	}

	private static int max(int a, int b) {
		if (a > b) {
			return a;
		}
		return b;
	}

	public static void main(String[] args) {
		String s1 = "ABCBDAB";
		// char[] c1 = new char[s1.length() + 1];
		// char[] t1 = s1.toCharArray();
		// c1[0] = (char) 0;
		// for (int i = 0; i < t1.length; i++) {
		// c1[i + 1] = t1[i];
		// }

		// StringBuffer用法
		char[] c1 = new StringBuffer().
						append((char) 0).
						append(s1).
						toString().
						toCharArray();
		// 如此一个方法链,就代表了上边的用法。

		String s2 = "BDCABA";
		char[] c2 = new char[s2.length() + 1];
		char[] t2 = s2.toCharArray();
		c2[0] = (char) 0;
		for (int i = 0; i < t2.length; i++) {
			c2[i + 1] = t2[i];
		}

		int[][] bak = new int[c1.length][c2.length];

		System.out.println(lcs(c1, c2, c1.length - 1, c2.length - 1, bak));
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_临渔_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值