string 类的学习

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,和用到标注的形式从后往前移动。。

 

自己写了一个思路和上面一样:调试用了点时间,主要是下标位置问题。代码如下

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值