方法一:
String.format("%0" + n + "d", 0).replace("0",s);
方法二:
new String(new char[n]).replace("\0", s);
方法三:(JAVA 8)
String.join("", Collections.nCopies(n, s));
方法四:
public static String repeatString(String str, int n, String seg) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < n; i++) {
sb.append(str).append(seg);
}
return sb.substring(0, sb.length() - seg.length());
}
执行次数1000_000
耗时毫秒
1797
593
167
142
根据前面的总结和测试,相对而言,3和4的耗时比较少,多次测试的结果4都比3用时更少一点。
注重性能就选择3或4