代码
String str = "hello";
str = new StringBuilder(str).reverse().toString();
解释
首先点击reverse()方法,如下:
@Override
public StringBuilder reverse() {
super.reverse();
return this;
}
然后点击super后面的reverse()方法,如下:
public AbstractStringBuilder reverse() {
boolean hasSurrogates = false;
int n = count - 1;
for (int j = (n-1) >> 1; j >= 0; j--) {
int k = n - j;
char cj = value[j];
char ck = value[k];
value[j] = ck;
value[k] = cj;
if (Character.isSurrogate(cj) ||
Character.isSurrogate(ck)) {
hasSurrogates = true;
}
}
if (hasSurrogates) {
reverseAllValidSurrogatePairs();
}
return this;
}
可以看到里面的主要代码如下:
int n = count - 1;
for (int j = (n-1) >> 1; j >= 0; j--) {
int k = n - j;
char cj = value[j];
char ck = value[k];
value[j] = ck;
value[k] = cj;
}
作用是完成char[]数组中字符的交换,如果我们自己来实现的话,代码可以这样写,如下:
public class Test {
public static void main(String[] args) {
// 字符串
String str = "hello";
// 字符串中的字符数组
char[] value = str.toCharArray();
// 字符串长度
int count = str.length();
int n = count - 1;
for (int j = (n-1) >> 1; j >= 0; j--) {
int k = n - j;
char cj = value[j];
char ck = value[k];
// 字符交换
value[j] = ck;
value[k] = cj;
}
// 将反转之后的字符数组放入字符串之中
str = new String(value);
// 输出结果
System.out.println(str);
}
}