java中常用的字符串的截取方法

1、length() 字符串的长度   例:char chars[]={'a','b'.'c'};     String s=new String(chars);     int len=s.length();

2、charAt() 截取一个字符   例:char ch;     ch="abc".charAt(1); 返回'b'

3、getChars() 截取多个字符   void getChars(int sourceStart,int sourceEnd,char target[],int targetStart)   sourceStart指定了子串开始字符的下标,sourceEnd指定了子串结束后的下一个字符的下标。因此,子串包含从sourceStart到sourceEnd-1的字符。接收字符的数组由target指定,target中开始复制子串的下标值是targetStart。

 例:String s="this is a demo of the getChars method.";     char buf[]=new char[20];     s.getChars(10,14,buf,0);

4、getBytes()   替代getChars()的一种方法是将字符存储在字节数组中,该方法即getBytes()。

5、toCharArray()

6、equals()和equalsIgnoreCase() 比较两个字符串

7、regionMatches() 用于比较一个字符串中特定区域与另一特定区域,它有一个重载的形式允许在比较中忽略大小写。   boolean regionMatches(int startIndex,String str2,int str2StartIndex,int numChars)   boolean regionMatches(boolean ignoreCase,int startIndex,String str2,int str2StartIndex,int numChars)

8、startsWith()和endsWith()   startsWith()方法决定是否以特定字符串开始,endWith()方法决定是否以特定字符串结束

9、equals()和==   equals()方法比较字符串对象中的字符,==运算符比较两个对象是否引用同一实例。   例:String s1="Hello";     String s2=new String(s1);     s1.eauals(s2); //true     s1==s2;//false

10、compareTo()和compareToIgnoreCase() 比较字符串

11、indexOf()和lastIndexOf()   indexOf() 查找字符或者子串第一次出现的地方。   lastIndexOf() 查找字符或者子串是后一次出现的地方。

12、substring()   它有两种形式,第一种是:String substring(int startIndex)          第二种是:String substring(int startIndex,int endIndex)

13、concat() 连接两个字符串

14 、replace() 替换   它有两种形式,第一种形式用一个字符在调用字符串中所有出现某个字符的地方进行替换,形式如下:   String replace(char original,char replacement)   例如:String s="Hello".replace('l','w');   第二种形式是用一个字符序列替换另一个字符序列,形式如下:   String replace(CharSequence original,CharSequence replacement)

15、trim() 去掉起始和结尾的空格

16、valueOf() 转换为字符串

17、toLowerCase() 转换为小写

18、toUpperCase() 转换为大写

19、StringBuffer构造函数   StringBuffer定义了三个构造函数:   StringBuffer()   StringBuffer(int size)   StringBuffer(String str)   StringBuffer(CharSequence chars)      (1)、length()和capacity()     一个StringBuffer当前长度可通过length()方法得到,而整个可分配空间通过capacity()方法得到。      (2)、ensureCapacity() 设置缓冲区的大小     void ensureCapacity(int capacity)

  (3)、setLength() 设置缓冲区的长度     void setLength(int len)

  (4)、charAt()和setCharAt()     char charAt(int where)     void setCharAt(int where,char ch)

  (5)、getChars()     void getChars(int sourceStart,int sourceEnd,char target[],int targetStart)

  (6)、append() 可把任何类型数据的字符串表示连接到调用的StringBuffer对象的末尾。     例:int a=42;       StringBuffer sb=new StringBuffer(40);       String s=sb.append("a=").append(a).append("!").toString();

  (7)、insert() 插入字符串     StringBuffer insert(int index,String str)     StringBuffer insert(int index,char ch)     StringBuffer insert(int index,Object obj)     index指定将字符串插入到StringBuffer对象中的位置的下标。

  (8)、reverse() 颠倒StringBuffer对象中的字符     StringBuffer reverse()

  (9)、delete()和deleteCharAt() 删除字符     StringBuffer delete(int startIndex,int endIndex)     StringBuffer deleteCharAt(int loc)

  (10)、replace() 替换     StringBuffer replace(int startIndex,int endIndex,String str)

  (11)、substring() 截取子串     String substring(int startIndex)     String substring(int startIndex,int endIndex)

** 
* 输入一个字符串和字节数,输出为按字节截取的字条符串,但要保证汉字不被截半 
* @author Administrator 
* 
*/ 
public class Ceshi { 
public static void main(String[] args) { 
  String str = "sfsfs中国sdfsdfsfd"; 
  
  System.out.println(substring(str, 10)); 
} 

private static String substring(String str, int interceptLength){ 
  StringBuilder sb = new StringBuilder(); 
  
  for(int i=0; i<interceptLength; i++){ 
   sb.append(str.charAt(i)); 
  } 
  return sb.toString(); 
} 
} 
------------------------------------------------------------------- 
import java.util.StringTokenizer; 
  /** *//** 
  public class SplitTest { 
  public static void main(String[] args) { 
  SplitTest st = new SplitTest(); 
  // st.splitTest01(); 
  //st.splitTest02(); 
  st.StringTokenizierTest(); 
  } 
  public void splitTest01() { 
  String s = "01111:aa:哈哈"; 
  /**//* 
  * limit 该值用来限制返回数组中的元素个数 
  */ 
  String[] s1 = s.split(":"); 
  System.out.println(s1[0]); 
  /**//* 
  * -1表示如果为空也能区分出来 
  */ 
  String[] s2 = s.split(":", -1); 
  System.out.println(s2[0]); 
  String[] s3 = s.split(":", 1); 
   System.out.println(s3[0]); 
  } 
  public void splitTest02() { 
  // “.”和“|”都是转义字符,必须得加"\" 
  String s = "bulktree.oakertree.laoshulin"; 
  String ss = "bulktree|oakertree|laoshulin"; 
  String sss = "bulktree.oakertree|laoshulin"; 
  String[] s1 = s.split("\."); 
  System.out.println(s1[0]); 
  String[] s2 = ss.split("\|"); 
  System.out.println(s2[0]); 
  /**//* 
  * 如果有多个分隔符,可以用"|"作为连字符 
  */ 
  String[] s3 = sss.split("\.|\|"); 
  System.out.println(s3[1]); 
  } 
  /**//* 
  * 构造字符串的StringTokenizer对象测试 
  */ 
  public void StringTokenizierTest() { 
  String s = "I am a student,bulktree"; 
  StringTokenizer str = new StringTokenizer(s); 
  // 返回nextToken方法被调用的次数,分隔符的数量 
  System.out.println(str.countTokens()); 
  // 是否有分隔符 
  while(str.hasMoreTokens()) { 
  System.out.println(str.nextToken()); 
  } 
  } 
  } 

  

原文地址:https://www.cnblogs.com/gxbk629/p/3625533.html