문자열 파싱(parsing)을 위한 정보를 제공하는 클래스로
파싱(parsing)하고자 하는 문자열을 인자로 받아 생성하는데,
여기에서 파싱(parsing)이란 하나의 문자열을 여러 문자열로
나누는 작업을 의미하게 되며, 이 때 나누는 단위가 되는
문자열을 토큰(token)이라고 한다.
StringTokenizer 클래스를 사용하기 위해서는
java.util 패키지의 String.Tokenizer를 import 해야 한다.
★StringTokenizer 클래스는 호환성을 유지하는 목적으로
보관 유지되고 있으며★ 문자열을 파싱(parsing)하기 위해서는
String 클래스의 split() 메소드난 java.util.regex 패키지를
사용할 것을 권장하고 있다.
import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.io.IOException;
import java.util.StringTokenizer;
public class Test136
{
public static void main(String[] args) throws IOException
{
String strTemp;
String[] strArr;
int n;
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
System.out.print("파싱할 문자열 입력(컴마구분) : "); // "사과,딸기,바나나,토마토"
strTemp = br.readLine();
// StringTokenizer 클래스 인스턴스 생성
StringTokenizer st = new StringTokenizer(strTemp, ","); //위에 적은거 2번째 생성자
//-- strTemp를 대상 문자열로...
// 『,』를 구분자로...
strArr = new String[st.countTokens()]; // st.countTokens() -> 4
//-- int countTokens()
// : 파싱된 문자열의 갯수를 반환(리턴)한다.
n = 0;
while (st.hasMoreTokens()) // true / false
{
strArr[n++] = st.nextToken(); // 해즈모어토큰즈는 망만보는아이 넥스트토큰은 가지고 오는 역할
// 다음 값이 있으면 해즈모어토큰이 트루반환
}
//-- 『hasMoreTokens』
// : 사용할 수 있는 토큰이 남아있는 경우 true 를 반환.
// 더 이상 사용할 토큰이 남아있지 않은 경우 false 를 반환.
// 확인 결과만 반환할 뿐...
// 실제 내용을 읽어들이는 헤드(▼)를 이동시키지 않는다.
//-- 『nextToken()』
// : 다음 토큰을 얻어온다.
// 다음 토큰을 얻어오며 헤드(▼)를 이동시키게 된다.
// 구분자를 바꾸었을 경우 다음 호출에도
// 바뀐 구분자를 이용하여 토큰을 분리한다.
System.out.print("파싱된 토큰(문자열) : ");
for (String str : strArr)
System.out.print(str + " ");
System.out.println();
//--==>>파싱할 문자열 입력(컴마구분) : 사과,딸기,포도,복숭아
// 파싱된 토큰(문자열) : 사과 딸기 포도 복숭아
// 계속하려면 아무 키나 누르십시오 . . .
}
}