자바와 C# 에서의 문자열 조합 관련 질문
유리
그동안 flex를 하다가 이번에 asp.net을 하게 되었습니다.
(자바를 하고 싶었지만.....ㅜㅜ)
다름 아니라..자바에서 문자열 조합을 할때는 StringBuffer 클래스의 append 메소드를 사용하는것이
string 에서 + 를 사용하는 것보다 더 효율적이라는 글을 봤었습니다. (어딘지는 가물가물 하네요..)
예를 들어서
String str = aa + bbb + cccc + ddd
보다는
StringBuffer strBuf;
strBuf.append(aa);
strBuff.append(bb);
strBuff.append(cc);
strBuff.append(dd);
그래서 긴 sql 문같은 경우 StringBuffer를 사용해서 만들었습니다.
그런데 오늘 Asp.net을 공부하기 위해 관련된 사이트에서
StringBuilder에 대한 글을 읽었ㅤㄴㅡㄷ데 자바의 StringBuffer 와 비슷한 기능을 하는거 같습니다.
(http://www.taeyo.pe.kr/Columns/View.aspx?SEQ=250&PSEQ=23&IDX=2)
둘다 똑같이 append() 를 사용해서 문자열을 조합하는 것이...
근데 그 글에서는 Sql 쿼리문같은 경우는 append()를 사용하는 것보다는 + 를 사용하는 것이 더 효율적이라고 하네요...요약...
자바에서 문자열 조합시 StringBuffer를 사용하는것이 + 연산자를 사용하는 것보다 효율적인지 궁금합니다.
(예 - 긴 sql 문 작성할때)
-
소유
당연히 + 연산자 보다는 StringBuffer이 더 효율적입니다.
하지만,
요즘에 컴파일러들은 똑똑해서, String을 + 로 만들어 두면,
왠만해서는 알아서 StringBuffer로 만들어서 처리해 두게 됩니다.
( 사실 꽤나 오래전 sun의 java컴파일러도 그렇게 하고 있습니다. )
자바에서 Thread와 관련없는 부분이라면, StringBuffer말고, StringBuilder를 사용하세요~
StringBuilder는 String -
파도
String StringBuffer로 네이년을 검색하다 속도 차이에 대한 것을 보게 됐는데요..
String은 컴파일시 결정되고 StringBuffer는 런타임시 결정된다고 하네요..
그러므로 sql문 같은 경우는 런타임시 변수의 값이 변하지 않으니 String이 더 효율적이라고 하네요.. 시간은 String가 2배 정도 빠른것으로 나오네요..
그리고 sql문을 + 연산자로 해서 매모리를 차지 하더라도 sql은 그리 길지(?) 않으니 메모리 측면 -
하나
답변 감사합니다. ^^
근데...C#에서는 + 연산자가 더 효율적이라고 한느데.....sql 문과 같은 경우...
햇갈리네요......ㅡㅡa;;,,,,,, -
원술
+ 연산을 사용하는 것보다 StringBuffer의 append() 메소드를 사용하는 것이
메모리나 성능면에서 월등이 우수 합니다.
String 의 + 연산일 경우 모든 연산의 String이 메모리에 다 생성 되게 되지만
StringBuffer의 경우는 하나의 인스턴스 위에 붙여지게 됩니다.
긴 문자열의 조합에는 StringBuffer 또는 StringBuilder를 사용해야 효율적입니다.