final的class,不能被继承;
实现的接口: java.io.Serializable, Comparable<String>, CharSequence
属性:
/** The value is used for character storage. */
private final char value[];//存储字符串
/** The offset is the first index of the storage that is used. */
private final int offset;//字符串第一个位置
/** The count is the number of characters in the String. */
private final int count;//字符串的数量
/** Cache the hash code for the string */
private int hash; // Default to 0
/** use serialVersionUID from JDK 1.0.2 for interoperability */
private static final long serialVersionUID = -6849794470754667710L;
构造方法如下:
public String()构造函数
public String(){
this.offset=0;
this.count=0;
this.value=new char[0];
}
public String(String original)构造函数
public String(char value[])构造函数
public String(char value[],int offset,count)
public String(int[] codePoints, int offset, int count)
public String(StringBuffer buffer)通过StringBuffer进行构造
public String(StringBuilder builder)通过StringBuilder进行构造
String(int offset,int count,char value[])包可见的构造函数,提高速度
- indexof(String s)方法调用的 代码如下:
- repace()的方法代码如下:
上面代码实现的主要是:先找到位置,然后复制找到的位置到buf字符串中。然后遍历后面的字符串是否有要替代的字符。
优点是:当没有找到一个要替代的字符时候 不会创建buf缓存。
我自己写的代码如下:
这样的话空间buf是一定创建了。
- subString
的代码如下: 直接重新构造一个从 beginIndex 到endIndex的string
(beginIndex == 0) && (endIndex == count) 如果是本身的话就返回this本身。
- trim()
代码如下:返回字符串的副本,忽略前导空白和尾部空白.用变量st和len来表示前或尾部有空白,当都没空白的时候
返回this本身,否则返回substring(st,len)从前面非空白处到后面非空白处。
代码优点:找出前或后面的空白位置,然后调用substring(st,len)截取从st到len的位置string。or return this.
- lastIndexOf()
代码如下:主要是从后面往前查询子str.同时注意要匹配的len,和用到标注的形式从后往前移动。。
自己写了一个思路和上面一样:调试用了点时间,主要是下标位置问题。代码如下