Java.io.StreamTokenizer.slashStarComments()方法實例
java.io.StreamTokenizer.slashStarComments(boolean flag) 方法確定是否標記生成器識彆C風格的注釋。如果flag參數為true,則此流標記者承認C風格的注釋。/*和*/被丟棄的連續出現,之間的所有文本。如果flag參數為false,則C風格的注釋不會得到特殊對待。
聲明
以下是java.io.StreamTokenizer.slashStarComments()方法的聲明
public void slashStarComments(boolean flag)
參數
-
flag -- true表示承認並忽略C語言風格的注釋。
返回值
這個方法冇有返回值
異常
-
NA
例子
下麵的例子顯示java.io.StreamTokenizer.slashStarComments()方法的用法。
package com.yiibai; import java.io.*; public class StreamTokenizerDemo { public static void main(String[] args) { String text = "Hello. This /*is a text 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); // set slash-star comments as recognizable st.slashStarComments(true); // 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: 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: BHello. Word: This Word: will Word: be Word: split Word: into Word: tokens. Number: 1.0 + encountered. Number: 1.0 = encountered. Number: 2.0 End of File encountered.