Java String API详解 - 不知道的就不懂Java

一、前言

众所周知,无论使用哪一门编程语言,和字符串打的交道总是非常之多的。如果恰好使用的编程语言在字符串处理方面,API很全的话,就可以省去很多麻烦。就现在的使用体验来说,JAVA在字符串处理方面还是挺方便的。这篇博文主要是给大家总结一下java中,有关String的那些常见的API,日后大家使用时,可以方便大家查询。

二、常见API

  • 构造器

Java中,一切皆对象,String也是。如果是对象的话,那第一个想到的函数自然而然就是构造器啦!语法如下:

String str = new String("I am a lucky string."); //构造器

我们知道String的初始化还有另外一种方式

String str = "I am a lucky string"

这两种初始化方式有区别吗?回答是,当然有,区别还不小。不过本文在这一方面就不赘述了,想要了解的同学可以参考这篇博客点击打开链接

  • length()

length求一个字符串的长度,如下所示

System.out.println("My length is " + str.length()); //length()
  • charAt()

char charAt(int index),返回String中index下标位置处的char,若index不合法,抛出IndexOutOfBoundsException异常。例子如下:

System.out.println("My favoriate character is " + str.charAt(8));  //charAt() Output:u
  • getChars

public void getChars(int srcBegin, int srcEnd, char dst[], int dstBegin),将String源中下标从srcBegin到srcEnd的字符串,复制到目标字符串中,从下标从dstBegin开始复制。当然如果下标有一个不合法,也会抛出IndexOutOfBoundsException异常。例子如下:

char dst[] = {'a', 'p', 'o', 'o', 'r', 'g', 'i', 'r', 'l'};
		System.out.println("Now I want to pass my lucky to a good guy");
		str.getChars(7, 12, dst, 0);    //getChars(),Output:luckygirl
  • getBytes()

用平台默认的编码方式对String进行编码,并将结果储存到一个新的byte数组中。例子如下:

byte[] b_gbk = str.getBytes();  //getBytes()
  • toCharArray()

将String转换成一个char数组,例子如下:

dst = str.toCharArray(); //toCharArray()
System.out.println(dst);   //output:I am a lucky string.
  • equals()

public boolean equals(Object anObject)比较源String和anObject内容是否相等,注意“=”比较的是引用是否相等。二者的差别本文也不赘述,详情请见点击打开链接

  • equalsIgnoreCase()

用法类似equals(),只不过比较时忽略大小写。

  • compareTo()

public int compareTo(String anotherString),按字典顺序比较两个String的大小哦。字典顺序是说a<b<c,返回值有三种可能:1,0,-1分别表示大于,等于,小于。例子如下:

if (str.compareTo("I am a unlucky string.") > 0) {   //compareTo(),Output:I am smaller
	System.out.println("I am bigger");
} else {
	System.out.println("I am smaller");
}
  • contains()

boolean contains(CharSequence s),判断源String中是否含有s。包含则返回1,不包含则返回0。关于什么是CharSequence,本文不赘述,请自行百度。例子如下:

if (str.contains("lucky")) {                             //contains(),Output:<span style="font-family: Arial, Helvetica, sans-serif;">I contain lucky word</span>
	System.out.println("I contain lucky word");
} else {
	System.out.println("I don't contain lucky word");
}


  • contentEquals()

boolean contentEquals(StringBuffer sb),方法比较字符串到指定的CharSequence。其结果是true当且仅当此String指定序列相同的char值序列。例子如下:

StringBuffer strBuf = new StringBuffer("I am a lucky string.");
	if (str.contentEquals(strBuf)) {                             //contentEquals(),Output:The same
		System.out.println("The same");
	} else {
		System.out.println("Diffenent");
	}
  • regionMatches()

boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)。第一个参数ignoreCase表示比较时是否需要忽略大小,从toffset下标开始比较String和从下表ooffset开始String other是否相等,len表示指定比较的长度。例子如下:

String strNew = new String("I AM A LUCKY STRING.");
		if (str.regionMatches(true, 7, strNew, 7, 5)) {                             //regionMatches()
			System.out.println("The same");  //输出这一行
		} else {
			System.out.println("Diffenent");
		}
  • startsWith()

boolean startsWith(String prefix)判断是否以prefix开头,是返回true,反之,则返回false

  • boolean endsWith(String suffix)

判断是否以prefix结尾,是返回true,反之,则返回false

  • indexOf()

int indexOf(int ch),从左往右查找ASCII码为ch的字符,如果存在则返回该字符的下标。如果不存在,则返回-1

  • lastIndexOf()

int indexOf(int ch),从右往左查找ASCII码为ch的字符,如果存在则返回该字符的下标。如果不存在,则返回-1。和上面indexof一起的例子如下所示:

System.out.println(str.indexOf(97));          //indexOf()     输出:2   
		System.out.println(str.lastIndexOf(97));         //lastIndexOf() 输出:5
  • substring()

String substring(int beginIndex, int endIndex),返回String下标从beginIndex到下标endIndex-1之间的字符串。例子如下:

System.out.println(str.substring(7, 11));        //substring,输出:	luck
  • concat()

拼接两个字符串。例子如下:

System.out.println(str.concat(" Do you like me? "));        //concat,输出:I am a lucky string. Do you like me?
  • replace()

String replace(char oldChar, char newChar),从这个函数原型中就可以看出就是将String中的oldChar替换成newChar啦。是全部替换哦,例子如下:

System.out.println(str.replace('a', 'A'));        //replace,输出:I Am A lucky string.
  • toUpperCase()和toLowerCase()

不解释,转成大写/小写。

  • trim()

将String两端的空白字符删除后,返回一个新的String对象。如果没有改变发生,则返回原String对象。例子如下:

strNew = "          I am a lucky string.            ";
		System.out.println(strNew.trim());        //trim,输出:I am a lucky string.
  • valueOf()

返回一个表示参数内容的String,参数可以是double,int,float,char,char[],long啊之类的,基本都可以。实际上就是类型转换啦!把别的类型的数据转换成String。例子如下:

System.out.println(str.valueOf(8.8));      //valueOf输出:8.8
  • intern()

为每一个唯一的字符序列生成且仅生成一个String引用。什么意思呢?就是说某一个字符序列已经存在的话,那么就返回该字符序列对应的引用,例子如下:

System.out.println(str3 == str4);         //输出:false
		str4 = (str1 + str2).intern();            //重点:intern()
		System.out.println(str3 == str4);         //输出:true

三、程序完整版

public class StringClass {
	
	public static void main(String[] args) {
		String str = new String("I am a lucky string."); //构造器
		System.out.println("My length is " + str.length()); //length()
		System.out.println("My favoriate character is " + str.charAt(8));  //charAt() Output:u
		char dst[] = {'a', 'p', 'o', 'o', 'r', 'g', 'i', 'r', 'l'};
		System.out.println("Now I want to pass my lucky to a good guy");
		str.getChars(7, 12, dst, 0);    //getChars(),Output:luckygirl
		System.out.println(dst);
		byte[] b_gbk = str.getBytes();  //getBytes()
		System.out.println(b_gbk);
		dst = str.toCharArray(); //toCharArray()
		System.out.println(dst);   //output:I am a lucky string.
		
		if (str.equals("I am a unlucky string.")) {   //equals()
			System.out.println("The same");
		} else {
			System.out.println("Diffenent");
		}
		
		if (str.equalsIgnoreCase("I AM A LUCKY STRING.")) {   //equalsIgnoreCase()
			System.out.println("The same");
		} else {
			System.out.println("Diffenent");
		}
		
		if (str.compareTo("I am a unlucky string.") > 0) {   //compareTo(),Output:I am smaller
			System.out.println("I am bigger");
		} else {
			System.out.println("I am smaller");
		}
		
		if (str.contains("lucky")) {                             //contains()
			System.out.println("I contain lucky word");
		} else {
			System.out.println("I don't contain lucky word");
		}
		
		StringBuffer strBuf = new StringBuffer("I am a lucky string.");
		if (str.contentEquals(strBuf)) {                             //contentEquals(),Output:The same
			System.out.println("The same");
		} else {
			System.out.println("Diffenent");
		}
		
		String strNew = new String("I AM A LUCKY STRING.");
		if (str.regionMatches(true, 7, strNew, 7, 5)) {                             //regionMatches()
			System.out.println("The same");
		} else {
			System.out.println("Diffenent");
		}
		
		if (str.startsWith("I")) {                             //startsWith()
			System.out.println("I start with I.");
		} else {
			System.out.println("I don't start with I.");
		}
		
		if (str.endsWith("string.")) {                             //endsWith()
			System.out.println("I end with string.");
		} else {
			System.out.println("I don't end with string.");
		}
		
		System.out.println(str.indexOf(97));          //indexOf()        
		System.out.println(str.lastIndexOf(97));         //lastIndexOf()
		System.out.println(str.substring(7, 11));        //substring,输出:	luck	
		System.out.println(str.concat(" Do you like me? "));        //concat,输出:I am a lucky string. Do you like me?	
		System.out.println(str.replace('a', 'A'));        //replace,输出:I Am A lucky string.
		System.out.println(str.toUpperCase());            //toUpperCase
		strNew = "          I am a lucky string.            ";
		System.out.println(strNew.trim());        //trim,输出:I am a lucky string.
		System.out.println(str.valueOf(8.8));      //valueOf输出:8.8
		
		
		String str1 = "a"; 
		String str2 = "bc"; 
		String str3 = "a"+"bc"; 
		String str4 = str1+str2; 

		System.out.println(str3 == str4);         //输出:false
		str4 = (str1 + str2).intern();            //重点:intern()
		System.out.println(str3 == str4);         //输出:true
	}
}

如有不足之处,欢迎指出。

    原文作者:爱上健身的菇凉
    原文地址: https://blog.csdn.net/XIAXIA__/article/details/41719327
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞