Обработка строк в Java - это то, что я пытаюсь научиться делать хорошо.В настоящее время я хочу взять строку и заменить любые символы, которые я найду.
Вот моя текущая неэффективная (и немного глупая IMO) функция.Это было написано, чтобы просто работать.
public String convertWord(String word)
{
return word.toLowerCase().replace('á', 'a')
.replace('é', 'e')
.replace('í', 'i')
.replace('ú', 'u')
.replace('ý', 'y')
.replace('ð', 'd')
.replace('ó', 'o')
.replace('ö', 'o')
.replaceAll("[-]", "")
.replaceAll("[.]", "")
.replaceAll("[/]", "")
.replaceAll("[æ]", "ae")
.replaceAll("[þ]", "th");
}
Я запустил 1.000.000 прогонов, и это заняло 8182мс.Итак, как мне следует изменить эту функцию, чтобы она стала более эффективной?
Найденное решение:
Преобразование функции в эту
public String convertWord(String word)
{
StringBuilder sb = new StringBuilder();
char[] charArr = word.toLowerCase().toCharArray();
for(int i = 0; i < charArr.length; i++)
{
// Single character case
if(charArr[i] == 'á')
{
sb.append('a');
}
// Char to two characters
else if(charArr[i] == 'þ')
{
sb.append("th");
}
// Remove
else if(charArr[i] == '-')
{
}
// Base case
else
{
sb.append(word.charAt(i));
}
}
return sb.toString();
}
Запуск этой функции 1.000.000раз занимает 518мс.Поэтому я думаю, что это достаточно эффективно.Спасибо за помощь, ребята:)