如何获取反转字符串(unicode 安全)
假设我们要还原以下字符串“áe”。
其 unicode 是“\u0061\u0301\u0065”。
恢复它的天真无邪的挑衅将是一个又一个的字符
private static String reverseStringNaive(String s) {
char[] characters = new char[s.length()];
for (int i = s.length() - 1; i >= 0; i--) {
int j = s.length() - i - 1;
characters[j] = s.charAt(i);
}
return new String(characters);
}
这给了我们“éa”(\u0065\u0301\u0061)当我们希望得到“eá”(\u0065\u0061\u0301)时。重音“'”应与“a”一起,而不是更改为“e”。
下面的代码为我提供了该字符串的预期结果:
private static String reverseString(String s) {
char[] characters = new char[s.length()];
for (int i = s.length() - 1; i >= 0; i--) {
int j = s.length() - i - 1;
if (Character.isLetterOrDigit(s.charAt(i)) || Character.isISOControl(s.charAt(i))) {
characters[j] = s.charAt(i);
} else {
characters[j] = s.charAt(i-1);
characters[j+1] = s.charAt(i);
i--;
}
}
return new String(characters);
}
我正在检查每个字符是字母,数字还是ISO控制。如果没有,我认为它应该与前一个字符粘在一起。
问题是,还有其他事情我应该检查或担心吗?我的阿普鲁克还天真吗?