답변:
한 가지 옵션은 다음과 같이 삭제 방법을 사용하는 것입니다.
StringBuffer sb = new StringBuffer();
for (int n = 0; n < 10; n++) {
sb.append("a");
// This will clear the buffer
sb.delete(0, sb.length());
}
또 다른 옵션 (비트 클리너)은 setLength (int len) 사용합니다 .
sb.setLength(0);
자세한 정보는 Javadoc 을 참조하십시오 .
를 재사용하는 가장 쉬운 방법 StringBuffer
은 방법을 사용하는 것입니다.setLength()
public void setLength(int newLength)
다음과 같은 경우가있을 수 있습니다.
StringBuffer sb = new StringBuffer("HelloWorld");
// after many iterations and manipulations
sb.setLength(0);
// reuse sb
setLength
대신 setlength
.
두 가지 옵션이 있습니다.
사용 :
sb.setLength(0); // It will just discard the previous data, which will be garbage collected later.
또는 다음을 사용하십시오.
sb.delete(0, sb.length()); // A bit slower as it is used to delete sub sequence.
루프 내에서 StringBuffer
또는 StringBuilder
객체를 선언하지 마십시오. 그렇지 않으면 반복 할 때마다 새 객체가 생성됩니다. 개체를 만들려면 시스템 리소스와 공간이 필요하며 시간도 걸립니다. 따라서 장기적으로 가능하면 루프 내에서 선언하지 마십시오.
각 반복마다 새 StringBuffer
(또는 더 나은 StringBuilder
)를 만드는 것이 좋습니다 . 성능 차이는 정말 미미하지만 코드는 더 짧고 간단합니다.
이미 좋은 대답입니다. StringBuffer 및 StringBuild 성능 차이에 대한 벤치 마크 결과를 추가하면 루프에서 새 인스턴스를 사용하거나 루프에서 setLength (0)을 사용합니다.
요약 : 큰 루프에서
매우 간단한 벤치 마크 (수동으로 코드를 변경하고 다른 테스트를 수행함) :
public class StringBuilderSpeed {
public static final char ch[] = new char[]{'a','b','c','d','e','f','g','h','i'};
public static void main(String a[]){
int loopTime = 99999999;
long startTime = System.currentTimeMillis();
StringBuilder sb = new StringBuilder();
for(int i = 0 ; i < loopTime; i++){
for(char c : ch){
sb.append(c);
}
sb.setLength(0);
}
long endTime = System.currentTimeMillis();
System.out.println("Time cost: " + (endTime - startTime));
}
}
루프의 새 StringBuilder 인스턴스 : 시간 비용 : 3693, 3862, 3624, 3742
StringBuilder setLength : 시간 비용 : 3465, 3421, 3557, 3408
루프의 새 StringBuffer 인스턴스 : 시간 비용 : 8327, 8324, 8284
StringBuffer setLength 시간 비용 : 22878, 23017, 22894
다시 StringBuilder setLength는 내 labtop이 StringBuffer setLength에 대해 그렇게 오래 사용하는 데 문제가 있는지 확인합니다. :-) 시간 비용 : 3448
StringBuffer sb = new SringBuffer();
// do something wiht it
sb = new StringBuffer();
이 코드가 더 빠르다고 생각합니다.