導航:首頁 > 文件教程 > guava按行讀取文件

guava按行讀取文件

發布時間:2023-08-13 12:25:24

A. java web項目啟動報錯,讀取組件guava-14.0.1.jar失敗,怎麼解決啊

你需要把guava-14.0.1.jar導入你的項目裡面。從網上下載這個jar包,如果你用eclipse IDE的話操作如下:右鍵單擊工程,選擇屬性,然後從彈出的對話框左邊的樹形結構中選擇java build path,中選擇add extenal jars,然後再在路徑中選擇你要加的jar包。之後再運行應該就沒問題了。

B. 怎麼查看jar包裡面的源碼

在Eclipse查看開發包jar源碼的方法如下:
1.選擇項目,右鍵中單擊【Properties】
2.【Java Build Path】-【Configure Build Path】-【Libraries】,在下面找到如:Guava-r09.jar包,展開它,選擇【Source attachment】,單擊右邊的【Edit…】按鈕。
3.在打開的窗口中,可選擇文件(jar\zip),目錄或工作空間中的jar文件,在這里我選擇External Folder…,選擇如E:/java project/guava即可。

4.連續單擊【OK】兩次回到Eclipse工作平台即可。
或者:
有源碼,把它加到eclipse中:
方法1:直接用壓縮軟體打開相應的jar包,然後把源碼拖進去壓縮一下,最後選中工程刷新一下ok。
方法2:右擊referenced libraries中需要導入源代碼的包,右擊properties->Java source attatchment,根據你源文件格式(源碼可以是直接src文件夾,也可以是壓縮成zip或jar後的壓縮文件)在右邊選擇合適的方式,最後點擊ok。
至於如何源碼打進jar包,在eclipse中打jar包的時候有個「Export java source files and resources」選項,選中它打包就ok;也可以如方法1那樣,用eclipse生成一般jar包之後,用壓縮軟體把src文件夾壓進去。

C. java怎樣讀取文件所有內容,主要是跳行問題謝謝了

如果是字元流文件。可以使用
java.nio.file.Files類的readAllLines將所有內容讀到一個List<String>里專

Google Guava庫也提供了類屬似的功能com.google.common.io.Files

static String
toString(File file,
Charset charset)
Reads all characters from a file into a String, using the given
character set.

D. 如何在eclipse中看jar包源代碼

面是導入的方法:
我用的是eclipse,
在Eclipse查看開發包jar源碼的方法如下:
1.選擇項目,右專鍵中單擊【屬Properties】
2.【Java Build Path】-【Configure Build Path】-【Libraries】,在下面找到如:Guava-r09.jar包,展開它,選擇【Source attachment】,單擊右邊的【Edit…】按鈕。
3.在打開的窗口中,可選擇文件(jar\zip),目錄或工作空間中的jar文件,在這里我選擇External Folder…,選擇如E:/java project/guava即可。

4.連續單擊【OK】兩次回到Eclipse工作平台即可。

E. Java 循環讀取文件導致內存溢出!

resultSet讀取的時候是以流的方式讀取的,每.next異常,讀取一定的數據。所有是不會內存溢出的。
你的程序內存溢出代碼
Vector<Vector<Object>> data = new Vector<Vector<Object>>();
while(reader.next()) {
Vector<Object> lineData = new Vector<Object>();
。。。。。。
}
你的data裡面放著了1W條的數據,並且沒一條都是一個linData,也就是說有1W個Vector對象,然後每一個line又有n個對象,內存的對象數量最少為1W*(n+1),在大的內存,這么玩也得掛。

解決方法:
1:直接用resultset,不把對象放到vector裡面。
2:分頁對取

F. java 如何讀取大文件

以下將從常規方法談起,通過對比來說明應該如何使用java讀取大文件。

1、常規:在內存中讀取
讀取文件行的標准方式是在內存中讀取,Guava 和Apache Commons IO都提供了如下所示快速讀取文件行的方法:
Files.readLines(new File(path), Charsets.UTF_8);
FileUtils.readLines(new File(path));
這種方法帶來的問題是文件的所有行都被存放在內存中,當文件足夠大時很快就會導致程序拋出OutOfMemoryError 異常。
例如:讀取一個大約1G的文件:
@Test
public void givenUsingGuava_whenIteratingAFile_thenWorks() throws IOException {
String path = ...
Files.readLines(new File(path), Charsets.UTF_8);
}
這種方式開始時只佔用很少的內存:(大約消耗了0Mb內存)
然而,當文件全部讀到內存中後,我們最後可以看到(大約消耗了2GB內存):
這意味這一過程大約耗費了2.1GB的內存——原因很簡單:現在文件的所有行都被存儲在內存中。
把文件所有的內容都放在內存中很快會耗盡可用內存——不論實際可用內存有多大,這點是顯而易見的。
此外,我們通常不需要把文件的所有行一次性地放入內存中——相反,我們只需要遍歷文件的每一行,然後做相應的處理,處理完之後把它扔掉。所以,這正是我們將要做的——通過行迭代,而不是把所有行都放在內存中。

2、文件流
FileInputStream inputStream = null;
Scanner sc = null;
try {
inputStream = new FileInputStream(path);
sc = new Scanner(inputStream, "UTF-8");
while (sc.hasNextLine()) {
String line = sc.nextLine();
// System.out.println(line);
}
// note that Scanner suppresses exceptions
if (sc.ioException() != null) {
throw sc.ioException();
}
} finally {
if (inputStream != null) {
inputStream.close();
}
if (sc != null) {
sc.close();
}
}
這種方案將會遍歷文件中的所有行——允許對每一行進行處理,而不保持對它的引用。總之沒有把它們存放在內存中:(大約消耗了150MB內存)

3、Apache Commons IO流
同樣也可以使用Commons IO庫實現,利用該庫提供的自定義LineIterator:
LineIterator it = FileUtils.lineIterator(theFile, "UTF-8");
try {
while (it.hasNext()) {
String line = it.nextLine();
// do something with line
}
} finally {
LineIterator.closeQuietly(it);
}
由於整個文件不是全部存放在內存中,這也就導致相當保守的內存消耗:(大約消耗了150MB內存)

閱讀全文

與guava按行讀取文件相關的資料

熱點內容
什麼的網路填 瀏覽:567
查國家文件去哪裡查 瀏覽:722
手機上怎麼發文件 瀏覽:64
數據分析過程6個步驟是哪些 瀏覽:622
baksmali最新版本 瀏覽:666
小米查找手機在哪個文件夾 瀏覽:906
編程進銷存用什麼語言 瀏覽:412
linux下獲取目錄下所有文件名 瀏覽:422
note5怎麼退出應用程序 瀏覽:71
qq個性群網名 瀏覽:224
激盪三十年版本哪個好 瀏覽:950
移動內網怎麼傳文件夾 瀏覽:581
extjslicense 瀏覽:338
文件夾變成ink 瀏覽:124
七彩虹h110裝機教程 瀏覽:351
word三個減號回車 瀏覽:844
生存之旅22041升級補丁 瀏覽:825
強行進入別人微信空間 瀏覽:208
win81有線未識別網路 瀏覽:616
a7m3圖片配置文件視頻 瀏覽:471

友情鏈接