其中value的定义如下:
/** The value is used for character storage. */
private final char value[];
复制代码
String类的一个构造方法为:
public String(String original) {
this.value = original.value;
this.hash = original.hash;
}
复制代码
可见,String在底层实际上是由一个用final关键字修饰的不可变的字符数组存储的。 String.charAt(index)就是返回value[index]。
2.int compareTo(String anotherString)
=====================================
逐个字符比较两个字符串,如果第一个字符和参数的第一个字符相等,则以第二个字符和参数的第二个字符做比较,以此类推,直至不等为止,返回该字符的ASCII码差值。 如果两个字符串不一样长,可对应字符又完全一样,则返回两个字符串的长度差值。
-
@param anotherString the {@code String} to be compared.
-
@return the value {@code 0} if the argument string is equal to
-
this string; a value less than {@code 0} if this string
-
is lexicographically less than the string argument; and a
-
value greater than {@code 0} if this string is
-
lexicographically greater than the string argument.
*/
public int compareTo(String anotherString) {
int len1 = value.length;
int len2 = anotherString.value.length;
int lim = Math.min(len1, len2);
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) { //逐个字符比较
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2; //同位置的字符不相等,返回该字符的ASCII码差值
}
k++;
}
return len1 - len2; //两个字符串不一样长,可对应字符又完全一样,则返回两个字符串的长度差值
}
复制代码
3.String concat(String str)
===========================
将指定的字符串拼接到该字符串的末尾。
-
@param str the {@code String} that is concatenated to the end
-
of this {@code String}.
-
@return a string that represents the concatenation of this object’s
-
characters followed by the string argument's characters.
*/
public String concat(String str) {
if (str.isEmpty()) {
return this;
}
int len = value.length;
int otherLen = str.length();
char buf[] = Arrays.copyOf(value, len + otherLen);
str.getChars(buf, len);
return new String(buf, true);
}
复制代码
4.boolean contains(CharSequence s)
==================================
当且仅当此字符串中包含指定的CharSequence 时才返回true。
-
@param s the sequence to search for
-
@return true if this string contains {@code s}, false otherwise
-
@since 1.5
*/
public boolean contains(CharSequence s) {
return indexOf(s.toString()) > -1;
}
复制代码
其中CharSequence是一个描述字符串结构的接口,像String、StringBuilder、StringBuffer都是它的子接口。
5.boolean startsWith(String prefix, int toffset)
================================================
测试在指定索引处开始的此字符串的子字符串是否以指定的前缀开头。 toffset为指定开始索引
public boolean startsWith(String prefix, int toffset) {
char ta[] = value;
int to = toffset;
char pa[] = prefix.value;
int po = 0;
int pc = prefix.value.length;
// Note: toffset might be near -1>>>1.
if ((toffset < 0) || (toffset > value.length - pc)) {
return false;
}
while (–pc >= 0) {
if (ta[to++] != pa[po++]) {
return false;
}
}
return true;
}
复制代码
6.boolean endsWith(String suffix)
=================================
测试此字符串是否以指定的后缀结尾。
public boolean endsWith(String suffix) {
//调用startsWith方法,相当从value.length - suffix.value.length索引处比较
return startsWith(suffix, value.length - suffix.value.length);
}
复制代码
7.boolean equals(Object anObject)
=================================
将此字符串与指定对象进行比较。
public boolean equals(Object anObject) {
if (this == anObject) {
return true;
}
if (anObject instanceof String) {
String anotherString = (String)anObject;
int n = value.length;
if (n == anotherString.value.length) {
char v1[] = value;
char v2[] = anotherString.value;
int i = 0;
while (n-- != 0) {
if (v1[i] != v2[i])
return false;
i++;
}
return true;
}
}
return false;
}
复制代码
8.String format(String format, Object… args)
==============================================
使用指定的格式字符串和参数返回格式化的字符串。
9.byte[] getBytes()
=====================
使用平台的默认字符集将此 String编码为字节序列,将结果存储到新的字节数组中。
public byte[] getBytes() {
return StringCoding.encode(value, 0, value.length);
}
复制代码
10.int hashCode()
=================
返回此字符串的哈希码。
public int hashCode() {
int h = hash;
if (h == 0 && value.length > 0) {
char val[] = value;
for (int i = 0; i < value.length; i++) {
h = 31 * h + val[i];
}
hash = h;
}
return h;
}
复制代码
11.int indexOf(int ch)
======================
返回指定字符第一次出现的字符串内的索引。
12.int lastIndexOf(int ch)
==========================
返回指定字符的最后一次出现的字符串中的索引。
13.boolean isEmpty()
====================
当且仅当length()为0时返回true。
public boolean isEmpty() {
return value.length == 0;
}
复制代码
14.int length()
===============
返回此字符串的长度。
public int length() {
return value.length;
}
复制代码
15.boolean matches(String regex)
================================
告诉这个字符串是否匹配给定的 regular expression (正则表达式)。
public boolean matches(String regex) {
return Pattern.matches(regex, this);
}
复制代码
16.String replaceAll(String regex, String replacement)
======================================================
用给定的字符串替换与给定的 regular expression匹配此字符串的每个子字符串。
17.String replaceFirst(String regex, String replacement)
========================================================
用给定的字符串替换与给定的 regular expression匹配此字符串的第一个子字符串。
18.String[] split(String regex)
=================================
将此字符串分割为给定的 regular expression的匹配。返回分割后的字符串数组。
public String[] split(String regex) {
return split(regex, 0);
}
public String[] split(String regex, int limit) {
/* fastpath if the regex is a
(1)one-char String and this character is not one of the
RegEx’s meta characters “.$|()[{^?*+\”, or
(2)two-char String and the first char is the backslash and
the second is not the ascii digit or ascii letter.
*/
char ch = 0;
if (((regex.value.length == 1 &&
“.$|()[{^?*+\”.indexOf(ch = regex.charAt(0)) == -1) ||
(regex.length() == 2 &&
regex.charAt(0) == ‘\’ &&
(((ch = regex.charAt(1))-‘0’)|(‘9’-ch)) < 0 &&
((ch-‘a’)|(‘z’-ch)) < 0 &&
((ch-‘A’)|(‘Z’-ch)) < 0)) &&
(ch < Character.MIN_HIGH_SURROGATE ||
ch > Character.MAX_LOW_SURROGATE))
{
int off = 0;
int next = 0;
boolean limited = limit > 0;
ArrayList list = new ArrayList<>();
while ((next = indexOf(ch, off)) != -1) {
if (!limited || list.size() < limit - 1) {
list.add(substring(off, next));
off = next + 1;
} else { // last one
//assert (list.size() == limit - 1);
list.add(substring(off, value.length));
off = value.length;
break;
}
}
// If no match was found, return this
if (off == 0)
return new String[]{this};
// Add remaining segment
if (!limited || list.size() < limit)
list.add(substring(off, value.length));
// Construct result
int resultSize = list.size();
if (limit == 0) {
while (resultSize > 0 && list.get(resultSize - 1).isEmpty()) {
resultSize–;
}
}
String[] result = new String[resultSize];
return list.subList(0, resultSize).toArray(result);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数同学面临毕业设计项目选题时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。
因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!
由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频
如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
tring[] result = new String[resultSize];
return list.subList(0, resultSize).toArray(result);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数同学面临毕业设计项目选题时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。
因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
[外链图片转存中…(img-ddoZy3BF-1712552088480)]
[外链图片转存中…(img-v5ydp8na-1712552088480)]
[外链图片转存中…(img-bg9Dhmbf-1712552088481)]
既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!
由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频
如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
[外链图片转存中…(img-1mfDSdHJ-1712552088481)]