如果您想要可读性和可维护性与性能,解决方案将取决于您。在测试了所有发布的答案并尝试了基本实现之后,最佳性能是基本实现。这是更多代码,但可能对您有用:
public interface IEvaluable {
void evaluate();
}
public class BasicImplementation implements IEvaluable {
private String string;
public BasicImplementation(String string) {
this.string = string;
}
//using the power of shadowing
public String[] getDigitsAsArray(String string) {
String[] data = new String[string.length()];
int j = 0;
for(int i = 0; i < string.length(); i++) {
if (Character.isDigit(string.charAt(i))) {
data[j++] = Character.toString(string.charAt(i));
}
}
String[] realData = new String[j];
for(int i = 0;i < j ;i++) {
realData[i] = data[i];
}
return realData;
}
@Override
public void evaluate() {
getDigitsByArray(string);
}
}
为了测试答案的性能,我实现了一个方法来测试结果:
public final class PerformanceEvaluator {
private IEvaluable evaluable;
public PerformanceEvaluator(IEvaluable evaluable) {
this.evaluable = evaluable;
}
public void evaluate() {
long initialTime;
long endTime;
initialTime = System.nanoTime();
try {
evaluable.evaluate();
} catch (Exception e) {
e.printStackTrace(System.out);
}
endTime = System.nanoTime();
System.out.println("Ellapsed time: " + (endTime - initialTime));
}
}
和主班
public class Main {
public static void main(String[] args) {
Main oMain = new Main();
oMain.evaluate("12");
oMain.evaluate("123456789098_)(56765432145");
oMain.evaluate("wbfiwyfwbn74g0t3h7t394mhg983hhon504n0er0n");
oMain.evaluate(
"1234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890");
oMain.evaluate("no digits");
}
public void evaluate(String string) {
PerformanceEvaluator performanceEvaluator =
new PerformanceEvaluator(new BasicImplementation(string));
performanceEvaluator.evaluate();
}
}
只需使用提供的解决方案创建实现IEvaluable
接口的其他类并自行测试。测试是在英特尔®酷睿™ i7-2675QM CPU @ 2.20GHz × 8 上的 Java 1.7.0_09 HotSpot 64 位服务器 VM 中完成的,Ubuntu 12.04 LT 上具有 8 GB RAM。
在我看来,仅基于这些测试用例:
- 如果您想使用正则表达式并更喜欢性能,请选择 @BlueBullet 答案。
- 如果您想坚持使用
String#split
,请选择@Pshemo 答案。