国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

解析Java的InputStream類并借助其讀取ppt文件

2019-11-26 14:50:59
字體:
來源:轉載
供稿:網友

1. 關于InputStream.read()
     在從數據流里讀取數據時,為圖簡單,經常用InputStream.read()方法。這個方法是從流里每次只讀取讀取一個字節,效率會非常低。     更好的方法是用InputStream.read(byte[] b)或者InputStream.read(byte[] b,int off,int len)方法,一次讀取多個字節。


2. 關于InputStream類的available()方法
    要一次讀取多個字節時,經常用到InputStream.available()方法,這個方法可以在讀寫操作前先得知數據流里有多少個字節可以讀取。需要注意的是,如果這個方法用在從本
地文件讀取數據時,一般不會遇到問題,但如果是用于網絡操作,就經常會遇到一些麻煩。比如,Socket通訊時,對方明明發來了1000個字節,但是自己的程序調用available()方法卻只得到900,或者100,甚至是0,感覺有點莫名其妙,怎么也找不到原因。其實,這是因為網絡通訊往往是間斷性的,一串字節往往分幾批進行發送。本地程序調用available()方法有時得到0,這可能是對方還沒有響應,也可能是對方已經響應了,但是數據還沒有送達本地。對方發送了1000個字節給你,也許分成3批到達,這你就要調用3次available()方法才能將數據總數全部得到。
      如果這樣寫代碼:

 int count = in.available(); byte[] b = new byte[count]; in.read(b);

      在進行網絡操作時往往出錯,因為你調用available()方法時,對發發送的數據可能還沒有到達,你得到的count是0。
         需要改成這樣:

 int count = 0; while (count == 0) {  count = in.available(); } byte[] b = new byte[count]; in.read(b);

3. 關于InputStream.read(byte[] b)和InputStream.read(byte[] b,int off,int len)

這兩個方法都是用來從流里讀取多個字節的,有經驗的程序員就會發現,這兩個方法經常 讀取不到自己想要讀取的個數的字節。比如第一個方法,程序員往往希望程序能讀取到b.length個字節,而實際情況是,系統往往讀取不了這么多。仔細閱讀Java的API說明就發現了,這個方法 并不保證能讀取這么多個字節,它只能保證最多讀取這么多個字節(最少1個)。因此,如果要讓程序讀取count個字節,最好用以下代碼:

 byte[] b = new byte[count]; int readCount = 0; // 已經成功讀取的字節的個數 while (readCount < count) {  readCount += in.read(bytes, readCount, count - readCount); }

      用這段代碼可以保證讀取count個字節,除非中途遇到IO異常或者到了數據流的結尾(EOFException)

4.讀取PowerPoint文件的例子

import java.io.InputStream;  import org.apache.lucene.document.Document; import org.apache.poi.hslf.HSLFSlideShow; import org.apache.poi.hslf.model.TextRun; import org.apache.poi.hslf.model.Slide; import org.apache.poi.hslf.usermodel.SlideShow;  public Document getDocument(Index index, String url, String title, InputStream is) throws DocCenterException {  StringBuffer content = new StringBuffer("");  try{   SlideShow ss = new SlideShow(new HSLFSlideShow(is));//is 為文件的InputStream,建立SlideShow   Slide[] slides = ss.getSlides();//獲得每一張幻燈片   for(int i=0;i<slides.length;i++){   TextRun[] t = slides[i].getTextRuns();//為了取得幻燈片的文字內容,建立TextRun   for(int j=0;j<t.length;j++){    content.append(t[j].getText());//這里會將文字內容加到content中去   }   content.append(slides[i].getTitle());   }   index.AddIndex(url, title, content.toString());  }catch(Exception ex){   System.out.println(ex.toString());  }  return null; } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东城区| 承德市| 湄潭县| 泰兴市| 临武县| 乐至县| 吉安市| 玉林市| 房山区| 西青区| 乳山市| 罗田县| 谢通门县| 乐平市| 乐清市| 高淳县| 江油市| 哈尔滨市| 会东县| 临邑县| 玉屏| 宁远县| 云林县| 固始县| 江山市| 临湘市| 渭源县| 岢岚县| 涟源市| 瑞金市| 威远县| 邢台市| 博客| 桂林市| 介休市| 保山市| 乐都县| 黔江区| 甘谷县| 逊克县| 弋阳县|