标签:nbsp tor 个数 except string ring 创建 static 常量
StreamTokenizer用来分隔字符串。
可以获取输入流并将其分析为Token(标记)。StreamTokenizer的nextToken方法将读取下一个标记。
功能 : 1、 将输入流分解成一组标记,允许一次读一个。分解过程由一张表和一些可以设置成各种状态的标志来控制。 2、读取的每个字节被认为是“\u0000”-“\u00FF”之间的字符。空格(“\u0000”-“\u0020”),字母(“A”-“Z”,“a”-“z”,“\u00A0”-“\u00FF”),数字,串引号(“,“),注释字符(“/”))。 3、做法:以一个InputStream作为源,创建一个StreamTokenizer对象,设置参数,循环调用nextToken,返回流中下一个标记的类型,并处理相关的值。 4、主要用于分析Java风格的输入;不是通用的标记分析器。 ttype域:nextToken后刚读取的标记类型。六种情况:
单字符标记:表示该字符(转换成整数)
引号串标记:引号符(String类型域sval存储了串内容)
TT_WORD(-3):字。TT_WORD指示已读到一个文字标记的常量
TT_NUMBER(-2):数,TT_NUMBER指示已读到一个数字标记的常量
TT_EOL(“\n”):行结束,指示已读到行末尾的常量
TT_EOF(-1):文件结束,TT_EOF指示已读到流末尾的常量
为了提高效率,使用BufferedReader,如下,创建StreamTokenizer对象
StreamTokenizer st =new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
为了从流中获取标记,可以调用StreamTokenizer的nextToken()方法。 调用nextToken()方法以后,如果标记是字符串,可用 String s=st.sval,如果是整数用 int n=(int) st.nval得到。
测试:
1 public static void streamTokenizerTest() throws IOException { 2 StreamTokenizer in = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in))); 3 //PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out)); 4 int a, b; 5 while(in.nextToken() != StreamTokenizer.TT_EOF){ 6 a = (int)in.nval;//默认为Double 7 in.nextToken(); 8 b = (int)in.nval; 9 //out.println(a + b); 10 System.out.println("a + b = "+(a+b)); 11 } 12 //out.flush(); 13 }
标签:nbsp tor 个数 except string ring 创建 static 常量
原文地址:https://www.cnblogs.com/Blog-cpc/p/12490116.html