Java.io.ByteArrayInputStream.mark()方法實例
java.io.ByteArrayInputStream.mark(int readAheadLimit) 方法設置流中的當前標記位置。默認情況下,標記ByteArrayInputStream類標記在現在的位置是0。
聲明
以下是java.io.ByteArrayInputStream.mark(int readAheadLimit)方法的聲明:
public void mark(int readAheadLimit)
參數
-
readLimit -- 該類整型值冇有任何意義。
返回值
此方法不返回任何值。
異常
-
NA
例子
下麵的例子顯示了java.io.ByteArrayInputStream.mark(int readAheadLimit)方法的用法。
package com.yiibai; import java.io.ByteArrayInputStream; import java.io.IOException; public class ByteArrayInputStreamDemo { public static void main(String[] args) throws IOException { byte[] buf = {65, 66, 67, 68, 69}; ByteArrayInputStream bais = null; try{ // create new byte array input stream bais = new ByteArrayInputStream(buf); // print bytes System.out.println("Byte read "+ bais.read()); System.out.println("Byte read "+ bais.read()); System.out.println("Byte read "+ bais.read()); System.out.println("Mark() invocation"); // mark() invocation; bais.mark(0); System.out.println("Byte read "+ bais.read()); System.out.println("Byte read "+ bais.read()); System.out.println("Reset() invocation"); // reset() invocation bais.reset(); System.out.println("Byte read "+ bais.read()); System.out.println("Byte read "+ bais.read()); }catch(Exception e){ // if I/O error occurs e.printStackTrace(); }finally{ if(bais!=null) bais.close(); } } }
讓我們來編譯和運行上麵的程序,這將產生以下結果:
Byte read 65 Byte read 66 Byte read 67 Mark() invocation Byte read 68 Byte read 69 Reset() invocation Byte read 68 Byte read 69