일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- DISTINCT
- EC2
- 책 정리
- vagrant
- 토비의스프링
- SSL
- sample
- TypeScript
- centos7
- WebHook
- AWS
- mariadb
- window
- TLS
- Client
- ssh
- 프로그래머스
- Git
- Linux
- 코딩테스트
- db
- github
- Spring Legacy Project
- Hibernate
- Jenkins
- Java
- spring boot
- jdbc
- spring
- docker
- Today
- Total
Woopii Vyeolog
String, StringBuffer, StringBuilder 본문
일단, 이 세 클래스는 모두 문자열을 저장하고 관리하는 클래스이다.
String은 불변(immutable)하고 StringBuffer,StringBuilder은 가변(mutable)하다.
String
String 클래스는 두 클래스와는 다르게,
literal방식을 통해 생성하게 되면 그 크기(공간)는 절대 변하지 않는다.
//리터럴로 생성하는 방식
String literal = "literal";
//new로 생성하는 방식
String new = new String("literal");
//위에서 "literal" 이라는 문자열을 String Pool에서 생성했기 때문에
//이후에 추가한 str1, str2, str3는 추가적으로 생성하지않고 똑같은 문자열을 가리킨다.
String str1 = "literal";
String str2 = "literal";
String str3 = "literal";
위 코드처럼 두가지 방식의 String class생성 방식이 있다. , 두 방식 모두 JVM 메모리 중 힙(heap) 영역에 생성된다는 점은 같다.
하지만 리터럴로 생성하면 특수하게 'String Pool' 이라는 공간에 생성된다. 이 메모리 공간에 생성된 문자열 값은 절대 변하지 않는다는 얘기다.
그래서 '+' 연산이나 .concat() 메소드를 이용해서 문자열 값에 변화를 줘도 메모리 공간 내의 값이 변하는 것이 아니라, "String Pool"이라는 공간 안에 메모리를 할당받아 새로운 String 클래스 객체를 만들어서 문자열을 나타내는 것이다.
이렇게 새로운 문자열이 만들어지면 '기존의 문자열'은 가비지 콜렉터에 의해 제거되야 하는 단점(언제 제거될지 모름)이 있다.
또한 이러한 문자열 연산이 많아진다면, 연산 한 번 할 때마다 계속해서 문자열 객체를 만드는 오버헤드가 발생하므로 성능이 떨어질 수 밖에 없다. (+ 연산에 내부적으로 char배열을 사용함)
대신 String 클래스의 객체는 불변하기 때문에 단순하게 읽어가는 조회연산에서는 타 클래스보다 빠르게 읽을 수 있는 장점이 있다. (추가 장점으로 불변하기 때문에 멀티쓰레드환경에서 동기화를 신경쓸 필요가 없다.)
즉, String 클래스는 문자열 연산이 적고, 자주 조회(참조) 하는 경우에 사용하면 유용하다 그리고 MultiThread 환경에서는 불변하는 성격 때문에 동기화를 신경쓰지 않아도 된다.
StringBuffer, StringBuilder
StringBuffer와 StringBuilder 클래스는 String과 다르게 mutable(변경가능)하다.
두 클래스 모두 문자열 연산을 할 때, 클래스는 한 번만 만들고(new), 메모리의 값을 변경시켜서 문자열을 변경한다.
그러므로 쓸데없이 중간에 문자열데이터들을 안 만들게 되니까 문자열 연산이 자주 있을 때 사용하면 성능적으로 좋다.
그리고 StringBuffer와 StringBuilder 클래스의 메서드들이 같으므로 상호 호환이 가능하다.
둘의 차이는
StringBuffer는 멀티쓰레드환경에서 synchronized키워드가 가능하므로 동기화가 가능하다. 즉, thread-safe하다. 반대로 StringBuilder는 thread-safe하지 않다.
StringBuilder는 동기화를 지원하지 않기 때문에 MultiThread 환경에서는 적합하지 않다.
대신 StringBuilder가 동기화를 고려하지 않기 때문에 싱글쓰레드 환경에서 StringBuffer에 비해 연산처리가 빠른 장점이 있다.
결론적으로, 문자열 연산이 많을 때 두 클래스를 사용하지만 멀티 쓰레드 환경에서는 StringBuffer를 사용하면 좋고, 싱글 쓰레드 환경이거나 멀티 쓰레드여도 굳이 동기화가 필요없는 경우에는 StringBuilder를 사용하는 것이 좋다.
출처/참고
https://jeong-pro.tistory.com/85
'java' 카테고리의 다른 글
[Java] Socket 통신, Tcp Server 샘플 (0) | 2022.04.02 |
---|---|
[디자인 패턴] Build Pattern, 빌더 패턴 (1) | 2021.02.24 |
Vector vs Arraylist (0) | 2020.02.28 |
garbage collecter (0) | 2020.02.19 |
JAVA에서의 메모리 관리 (Heap, Stack, Static ) (0) | 2020.02.14 |