String的实现方法简单介绍:

public final class String

    implements java.io.Serializable, Comparable<String>, CharSequence { }

三个接口解释:

java.io.Serializable:类的可序列化性由Java . io .serializable接口实现。未实现此功能的类接口的任何状态都不会序列化或反序列化。可序列化类的所有子类型本身可序列化。序列化接口没有方法或字段并且仅用于标识可序列化的语义。

要允许序列化不可序列化类的子类型,请执行以下操作子类型可能负责保存和还原supertype的public、protected和(如果可访问)状态程序包字段。子类型只能在以下情况下承担此责任它所扩展的类具有可访问的no -arg构造函数初始化类的状态。宣告类别是错误的如果不是这样,则可序列化。运行时将在以下位置检测到错误。

在反序列化期间,不可序列化类的字段将使用的public或protected no -arg构造函数初始化,子类必须可以访问no -arg构造函数可序列化。可序列化子类的字段将从流中恢复。

遍历图形时,可能遇到的对象不支持可序列化接口。在这种情况下notserializabeexception将被抛出并标识类的不可序列化对象。

Comparable:将此对象与指定的对象进行顺序比较。返回负整数、零或正整数,因为此对象较少大于、等于或大于指定对象

CharSequence:返回此字符序列的长度,长度是数字。

---------------------------------------------------------------------------------------------------

属性:

 private final char value[];

这是一个字符数组,并且是final类型,他用于存储字符串内容,从fianl这个关键字中我们可以看出,String的内容一旦被初始化了是不能被更改的。 虽然有这样的例子: String s = “a”; s = “b” 但是,这并不是对s的修改,而是重新指向了新的字符串, 从这里我们也能知道,String其实就是用char[]实现的。

 

private int hash;

缓存字符串的hash Code,默认值为 0;

 

private static final long serialVersionUID = -6849794470754667710L;

使用JDK 1 . 0 . 2中的serial versionuid实现互操作性;

通过查找资料得到:(因为String实现了Serializable接口,所以支持序列化和反序列化支持。Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常(InvalidCastException)。)

 

private static final ObjectStreamField[] serialPersistentFields =

        new ObjectStreamField[0];

类字符串是序列化流协议中的特殊大小写。ObjectStreamField[]:数组of objectstreamfields用于声明类的可序列化字段。

---------------------------------------------------------------------------------------------------

构造方法:

1.使用字符数组、字符串构造一个String

当我们使用字符数组创建String的时候,会用到Arrays.copyOf方法和Arrays.copyOfRange方法。这两个方法是将原有的字符数组中的内容逐一的复制到String中的字符数组中。

public String(char value[], int offset, int count) {

        if (offset < 0) {

            throw new StringIndexOutOfBoundsException(offset);

        }

        if (count <= 0) {

            if (count < 0) {

                throw new StringIndexOutOfBoundsException(count);

            }

            if (offset <= value.length) {

                this.value = "".value;

                return;

            }

        }

        // Note: offset or count might be near -1>>>1.

        if (offset > value.length - count) {

            throw new StringIndexOutOfBoundsException(offset + count);

        }

        this.value = Arrays.copyOfRange(value, offset, offset+count);

    }

2.使用字节数组构造一个String

在Java中,String实例中保存有一个char[]字符数组,char[]字符数组是以unicode码来存储的,String 和 char 为内存形式,byte是网络传输或存储的序列化形式。所以在很多传输和存储的过程中需要将byte[]数组和String进行相互转化。所以,String提供了一系列重载的构造方法来将一个字符数组转化成String,提到byte[]和String之间的相互转换就不得不关注编码问题。String(byte[] bytes, Charset charset)是指通过charset来解码指定的byte数组,将其解码成unicode的char[]数组,够造成新的String。

 

3.使用StringBuffer和StringBuider构造一个String

public String(StringBuffer buffer) {

        synchronized(buffer) {

            this.value = Arrays.copyOf(buffer.getValue(), buffer.length());

        }

    }

 

    public String(StringBuilder builder) {

        this.value = Arrays.copyOf(builder.getValue(), builder.length());

    }

 

有了StringBuffer或者StringBuilfer对象之后可以直接使用他们的toString方法来得到String。

 

4.一个私有的构造方法

String除了提供了很多公有的供程序员使用的构造方法以外,还提供了一个私有的构造方法

String(char[] value, boolean share) {

    // assert share : "unshared not supported";

    this.value = value;

}

该方法和 String(char[] value)有些区别

 

---------------------------------------------------------------------------------------------------

在方法的是现在还用到了很多方法:

length() 返回字符串长度   

isEmpty() 返回字符串是否为空   

charAt(int index) 返回字符串中第个字符 

char[] toCharArray() 转化成字符数组   

trim() 去掉全部空格   

toUpperCase() 转化为大写   

toLowerCase() 转化为小写   

String concat(String str) 拼接字符串  

 String replace(char oldChar, char newChar) 将字符串中的oldChar字符换成newChar字符,以上两个方法都使用了String(char[] value, boolean share);  

 boolean matches(String regex) 判断字符串是否匹配给定的regex正则表达式   

boolean contains(CharSequence s) 判断字符串是否包含字符序列s   

String[] split(String regex, int limit) 按照字符regex将字符串分成limit份。  

 String[] split(String regex)

 

---------------------------------------------------------------------------------------------------

简单介绍几种方法的功能:

hashCode

hashCode的实现其实就是使用数学公式:

s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]

 

replaceFirst、replaceAll、replace区别

String replaceFirst(String regex, String replacement)

String replaceAll(String regex, String replacement)

String replace(CharSequence target, CharSequence replacement)

 

 (1)replace的参数是char和CharSequence,即可以支持字符的替换,也支持字符串的替换 (2)replaceAll和replaceFirst的参数是regex,即基于规则表达式的替换,比如,可以通过replaceAll(“\d”, “*”)把一个字符串所有的数字字符都换成星号; 相同点是都是全部替换,即把源字符串中的某一字符或字符串全部换成指定的字符或字符串, 如果只想替换第一次出现的,可以使用 replaceFirst(),这个方法也是基于规则表达式的替换,但与replaceAll()不同的是,只替换第一次出现的字符串; 另外,如果replaceAll()和replaceFirst()所用的参数据不是基于规则表达式的,则与replace()替换字符串的效果是一样的,即这两者也支持字符串的操作;

 

intern()方法

public native String intern();

该方法返回一个字符串对象的内部化引用。String类维护一个初始为空的字符串的对象池,当intern方法被调用时,如果对象池中已经包含这一个相等的字符串对象则返回对象池中的实例,否则添加字符串到对象池并返回该字符串的引用。

 

 

String的实现方法简单介绍_编程