您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關java7中新I/O知識點有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
Java語言中改變較大的I/O API,被稱為“再次更新的I/O”或NIO.2(即JSR-203)。NIO.2是一組新的類和方法,主要存在于java.nio包內。下面來看一下它的優點。
它完全取代了java.io.File與文件系統的交互。
它提供了新的異步處理類,讓你無需手動配置線程池和其他底層并發控制,便可在后臺線程中執行文件和網絡I/O操作。
它引入了新的Network-Channel構造方法,簡化了套接字(Socket)與通道的編碼工作。
先看案例。老板讓你寫個程序,要掃描生產服務器上的所有目錄,找出曾經用各種讀/寫和所有者權限寫入過的所有properties文件。對于Java 6(及更低版本)而言,這幾乎是不可能完成的任務,因為:
沒有直接支持目錄樹導航的類或方法;
沒辦法檢測和處理符號鏈接;
用簡單操作讀不出文件的屬性(比如可讀、可寫或可執行)。
符號鏈接是一種特殊類型的文件,指向文件系統中的另外一個文件或位置——你可以把它理解為快捷方式。
用Java 7的NIO.2 API可以完成這個不可能的編程任務,它支持目錄樹的直接導航(Files.walkFileTree(),2.3.1節)、符號鏈接(Files.isSymbolicLink(),代碼清單2-4),能用一行代碼讀取文件屬性(Files.readAttributes(),2.4.3節)。
除此之外,老板還要求你在讀取這些properties文件時不能打斷主程序的處理流程。可最小的properties文件也有1MB,讀取這些文件很可能打斷程序的主流程!面對這一要求,在Java 5/6的時代,你很可能會用java.util.concurrent包中的類創建線程池和工作線程隊列,再用單獨的后臺線程讀取文件。我們在第4章將會討論到,現在Java中的并發仍然相當困難,并且非常容易出錯。借助Java 7和NIO.2 API,你可以用新的AsynchronousFileChannel(2.5節),不用指定工作線程或隊列就可以在后臺讀取大型文件。咻!
這個新API非常有用,盡管它不能幫你沖咖啡,但它的發展趨勢可在那兒擺著呢。
第一個趨勢是對其他數據存儲方法的探索,特別是在非關系或大數據集領域。你可能很快就會遇到讀寫大文件(比如微博上的大型報告文件)的問題。NIO.2可以幫助你用一種異步、有效的方式讀寫大文件,還能利用底層操作系統的特性。
第二個趨勢是多核CPU的發展,使得真正并發且更快的I/O成為可能。并發是個難以掌握的領域2,但NIO.2會助你一臂之力,它為多線程文件和套接字訪問的應用提供了一個簡單的抽象層。即便你不直接使用這些特性,它們也會對你的編程生涯產生極大影響,因為IDE、應用服務器和各種流行的框架會大量應用這些特性。
深入探討了并發計算可能給你的編程生涯帶來的微妙復雜性。
這些只是NIO.2會對你有哪些幫助的例子。如果NIO.2可以解決你眼下面臨的一些問題,本章的內容就是為你準備的!否則,你
可以在接到Java I/O 任務時再回來。
本章你會體驗到Java 7新I/O的能力,以便你能夠開始編寫基于NIO.2的代碼,并有信心探索新的API。除此之外,這些API還使用了一些第1章提到的特性,這證明Java 7確實會使用自己的特性。
將try-with-resources和NIO.2中的新API結合起來可以寫出非常安全的I/O程序,這在Java中還是破天荒的第一次!
我們覺得你很可能會用到新的文件I/O能力,所以本章會非常詳細地介紹。你需要從了解新的文件系統抽象層開始,即先了解Path和它的輔助類。在Path之上,你會接觸到常用的文件系統操作,比如復制和移動文件。
感謝各位的閱讀!關于“java7中新I/O知識點有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。