Java StreamTokenizer normalChar()方法及示例
StreamTokenizer类ordinaryChar()方法
normalChar()方法在java.io包中可用。
normalChar()方法用于标识给定字符在此StreamTokenizer中是“普通”字符,该字符具有注释char,字符串定界符,空格等。当解析器遇到此类字符时,解析器会将其视为单个字符。字符标记并将ttype字段设置为char值。
normalChar()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。
normalChar()方法在识别普通字符时不会引发异常。
语法:
public void ordinaryChar(int character);
参数:
int字符–表示字符。
返回值:
该方法的返回类型为void,不返回任何内容。
示例
//Java程序演示示例
// of void ordinaryChar(int character) method of //StreamTokenizer-
import java.io.*;
public class OrdinaryChar {
public static void main(String[] args) {
String str = "Hi, This is a mathematical expression : \n" +
" 2 * 4 = 8 \t" + "8 + 5 = 13";
try {
//实例化FileOutputStream和ObjectOutputStream-
FileOutputStream fos_stm = new FileOutputStream("D:\\includehelp.txt");
ObjectOutputStream obj_out_stm = new ObjectOutputStream(fos_stm);
//通过使用writeUTF()方法是
//将给定的字符串写入文件
obj_out_stm.writeUTF(str);
obj_out_stm.flush();
//实例化FileOutputStream和ObjectOutputStream-
ObjectInputStream obj_in_stm = new ObjectInputStream(new FileInputStream("D:\\includehelp.txt"));
//实例化StreamTokenizer和Reader-
Reader reader = new BufferedReader(new InputStreamReader(obj_in_stm));
StreamTokenizer st = new StreamTokenizer(reader);
//通过使用ordinaryChar()方法是
//设置普通字符'\t'
//丢弃任何特殊含义集
//以前
st.ordinaryChar('\t');
//在这里,我们开始考虑
//文件不为空
boolean end_of_file = false;
while (!end_of_file) {
//通过使用nextToken()方法是
//解析流中的下一个标记
int token = st.nextToken();
switch (token) {
case StreamTokenizer.TT_EOF:
System.out.println("End of File Found");
end_of_file = true;
break;
case StreamTokenizer.TT_EOL:
System.out.println("End of Line Found");
break;
case StreamTokenizer.TT_WORD:
System.out.println("word: " + st.sval);
break;
case StreamTokenizer.TT_NUMBER:
System.out.println("number: " + st.nval);
break;
default:
System.out.println((char) token + " Found.");
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
}输出结果
? Found. word: Hi , Found. word: This word: is word: a word: mathematical word: expression : Found. number: 2.0 * Found. number: 4.0 = Found. number: 8.0 Found. number: 8.0 + Found. number: 5.0 = Found. number: 13.0 End of File Found