void resetSyntax()
描述 (Description)
java.io.StreamTokenizer.resetSyntax()方法重置此tokenizer的语法表,以便所有字符都是“普通的”。 有关普通字符的更多信息,请参阅ordinaryChar方法。
声明 (Declaration)
以下是java.io.StreamTokenizer.resetSyntax()方法的声明。
public void resetSyntax()
参数 (Parameters)
NA
返回值 (Return Value)
此方法不返回值。
异常 (Exception)
NA
例子 (Example)
以下示例显示了java.io.StreamTokenizer.resetSyntax()方法的用法。
package com.iowiki;
import java.io.*;
public class StreamTokenizerDemo {
public static void main(String[] args) {
String text = "Hello. This is a text \n that will be split "
+ "into tokens. 1 + 1 = 2";
try {
// create a new file with an ObjectOutputStream
FileOutputStream out = new FileOutputStream("test.txt");
ObjectOutputStream oout = new ObjectOutputStream(out);
// write something in the file
oout.writeUTF(text);
oout.flush();
// create an ObjectInputStream for the file we created before
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.txt"));
// create a new tokenizer
Reader r = new BufferedReader(new InputStreamReader(ois));
StreamTokenizer st = new StreamTokenizer(r);
// print the stream tokens
boolean eof = false;
do {
int token = st.nextToken();
switch (token) {
case StreamTokenizer.TT_EOF:
System.out.println("End of File encountered.");
eof = true;
break;
case StreamTokenizer.TT_EOL:
System.out.println("End of Line encountered.");
break;
case StreamTokenizer.TT_WORD:
System.out.println("Word: " + st.sval);
break;
case StreamTokenizer.TT_NUMBER:
// when a number is met, reset syntax
st.resetSyntax();
System.out.println("Number: " + st.nval);
break;
default:
System.out.println((char) token + " encountered.");
if (token == '!') {
eof = true;
}
}
} while (!eof);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
让我们编译并运行上面的程序,这将产生以下结果 -
Word: AHello.
Word: This
Word: is
Word: a
Word: text
Word: that
Word: will
Word: be
Word: split
Word: into
Word: tokens.
Number: 1.0
encountered.
+ encountered.
encountered.
1 encountered.
encountered.
= encountered.
encountered.
2 encountered.
End of File encountered.