[JAVA] 문자열 클래스
String 클래스
java.lang 패키지에 포함된 클래스로 문자열을 나타냄
String을 선언하는 방법은 크게 다음과 같이 두가지가 존재
// 리터털
String str2 = "JAVA";
// new 연산자
char data[] = {'J', 'A', 'V', 'A'};
String str2 = new String(data);
String str3 = new String("JAVA"); // str2, str3 모두 "JAVA" 문자열
여기서 String을 리터럴로 선언하는 것과 new 연산자를 이용해 선언하는 것과 굉장히 중요한 차이점이 존재!
String str1 = "JAVA";
String str2 = "JAVA";
if(str==str2) { // 두 객체의 메모리 주소를 비교
System.out.println("TRUE");
} else {
System.out.println("FALSE");
}
// 실행 결과
// TRUE
위의 예제에서 각각의 스트링 객체는 따로 선언되었으므로 str1의 메모리 주소와 str2 메모리 주소를 비교했을 때 다른 값이 나올 것으로 예상됐지만 결과는 같은 주소를 가지고있다고 나옴
이러한 결과가 나온 이유는? String Constant Pool!
String 객체는 내부적으로 intern() 메소드를 호출
intern 메소드는 String Constant Pool 에서 해당 문자열이 존재하는지 검색
존재하면 해당 문자열의 주소값을 반환 (위의 예시는 이에 해당)
존재하지 않으면 새로운 주소값을 할당하여 반환
예제
public class StringEx {
public static void main(String[] args) {
String a = new String(" C#");
String b = new String(",C++ ");
System.out.println(a + "의 길이는 " + a.length()); // 문자열의 길이(문자 개수)
System.out.println(a.contains("#")); // 해당 문자열을 가지고 있는지 확인
a = a.concat(b); // 문자열 연결
System.out.println(a);
a = a.trim(); // 문자열 앞 뒤 공백 제거
System.out.println(a);
a = a.replace("C#", "JAVA"); // 문자열 대치
System.out.println(a);
String s[] = a.split(","); // 문자열 분리
for (int i = 0; i < s.length; i++) {
System.out.println("분리된 문자열 " + i+1 + " : " + s[i]);
}
a = a.substring(5); // 인덱스 5번부터 끝까지 서브 스트링 리턴
System.out.println(a);
char c = a.charAt(2); // 인덱스 2의 문자 리턴
System.out.println(c);
}
}
// 실행 결과
// C#의 길이는 3
// true
// C#,C++
// C#,C++
// JAVA,C++
// 분리된 문자열 01 : JAVA
// 분리된 문자열 11 : C++
// C++
// +
StringBuffer, StringBuilder 클래스
String 객체의 문자열을 수정할 수 없다는 점, 메모리 낭비가 있다는 점을 보완하기 위해 사용
메모리 낭비에 대한 내용은 다음 예시를 나타냄
String str = new String("JAVA");
str = str + "_8";
// 문자열이 변경되면 기존의 객체를 버리고 새로운 객체를 메모리에 생성, 기존 객체는 GC에 의해 회수됨
따라서 간단한 문자열 처리를 할 때는 String 클래스를 이용하고, 문자열의 길이가 길거나 문자열이 수시로 변하는 경우는 StringBuffer 혹은 StringBuilder 클래스를 사용하면 좋음
예제
public class StringBufferBuilderEx {
public static void main(String[] args) {
// StringBuffer : 속도가 더 빠름
StringBuffer sf = new StringBuffer("I Love");
sf.append(" JAVA"); // 문자열 덧붙이기
System.out.println(sf);
sf.insert(6, " C++ And"); // 6번 인덱스에 문자열을 삽입
System.out.println(sf);
sf.replace(2, 6, "Hate"); // 2번 인덱스 ~ 6번 인덱스 전까지 문자열을 변경
System.out.println(sf);
sf.delete(15, 19); // 15번 인덱스 ~ 19번 인덱스 전까지 문자열을 삭제
System.out.println(sf);
sf.setLength(6); // 스트링 버퍼 내 문자열 길이 수정
System.out.println(sf);
// StringBuilder : 안정성이 더 좋음 (더 많이 사용 한다고 함)
StringBuilder sb = new StringBuilder("String Builder!");
System.out.println("sb = " + sb);
}
}
// 출력 결과
// I Love JAVA
// I Love C++ And JAVA
// I Hate C++ And JAVA
// I Hate C++ And
// I Hate
// sb = String Builder!
StringTokenizer 클래스
java.util 패키지에 포함된 클래스로 하나의 클래스를 여러 개의 문자열로 분리할 때 사용
구분문자 : 문자열을 분리할 때 사용되는 기준 문자
토큰 : 구분 문자로 분리된 문자열
오라클에서는 String 클래스의 split() 메소드 사용을 권장하지만, 사용법이 편해 여전히 많이 사용된다고 함
예제
public class StringTokenizerEx {
public static void main(String[] args) {
StringTokenizer st = new StringTokenizer("홍길동/장화/홍련/콩쥐/팥쥐", "/");
System.out.println("st.countTokens() = " + st.countTokens()); // 토큰의 개수
while(st.hasMoreTokens()) { // 토큰이 있는 동안
System.out.println(st.nextToken());
}
}
}
// 출력 결과
// st.countTokens() = 5
// 홍길동
// 장화
// 홍련
// 콩쥐
// 팥쥐
출처 : http://www.yes24.com/Product/Goods/61269276