国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Java 7 I/O新功能探秘:同步操作,多播與隨機存取

開發 后端
Java 7提供了一個新API訪問文件系統,但除此之外,JSR 203(NIO.2)還包含其它很多新特性,這個新版本的確新增了很多改善I/O編程的類。

Java 7將在今年年底正式發布,關于它的介紹也層出不窮,51CTO之前也報導了Java 7的七大新功能,以及Java 7的最新特性、代碼示例及性能測試方面的特性。而本文將會著重介紹Java 7 I/O方面的新特性:

關于Java 7的更多內容,歡迎訪問51CTO推薦專題:Java 7 下一代Java開發技術詳解

◆SeekableByteChannel:隨機訪問通道;
◆MulticastChannel:允許IP多播的通道;
◆NetworkChannel:新的網絡通道超級接口;
◆異步I/O API:新的API使I/O操作可以異步進行。

SeekableByteChannel

首先,Java 7包括新的ByteChannel – SeekableByteChannel,這個通道維護當前的位置,你可以讀寫該位置,并允許隨機訪問。使用這個類型的通道,你可以添加多個線程讀/寫在不同位置相同的線程。

  1. SeekableByteChannel channel1 = Paths.get("Path to file").newByteChannel(); //Simply READ  
  2. SeekableByteChannel channel2 = Paths.get("Path to file").newByteChannel(StandardOpenOption.READ, StandardOpenOption.WRITE); //READ and WRITE 

你可以使用下面這些方法操作位置和通道的大小。

◆long position():返回目前的位置;
◆long size():返回通道連接實體的當前大小,如通道連接的文件大小;
◆position(long newPosition):移動當前位置到某個地方;
◆truncate(long size):根據給定大小截斷實體。

position()和truncate()方法簡單地返回當前通道,允許鏈式調用。現在FileChannel實現了新的接口,使用所有FileChannel你都可以實現隨機訪問,當然你可以用它讀取一個文件:

  1. SeekableByteChannel channel = null;  
  2. try {  
  3.     channel = Paths.get("Path to file").newByteChannel(StandardOpenOption.READ);  
  4.     ByteBuffer buf = ByteBuffer.allocate(4096);  
  5.  
  6.     System.out.println("File size: " + channel.size());  
  7.  
  8.     String encoding = System.getProperty("file.encoding");  
  9.  
  10.     while (channel.read(buf) > 0) {  
  11.         buf.rewind();  
  12.  
  13.         byte[] bytearr = new byte[bytebuff.remaining()];  
  14.         buf.get(bytearray);  
  15.         System.out.print(new String(bytearray));  
  16.  
  17.         buf.flip();  
  18.  
  19.         System.out.println("Current position : " + channel.position());  
  20.     }  
  21. } catch (IOException e) {  
  22.     System.out.println("Expection when reading : " + e.getMessage());  
  23.     e.printStackTrace();  
  24. } finally {  
  25.     if (sbc != null){  
  26.         channel.close();  
  27.     }  

#p#
MulticastChannel

這個新的接口允許開啟IP多播,因此你可以向一個完整的組發送和接收IP數據報。多播實現了直接綁定本地多播設備,這個接口是通過DatagramChannel和AsynchronousDatagramChannel實現的。下面是從Javadoc中摘取的一個打開DatagramChannel t的簡單示例:

  1. NetworkInterface networkInterface = NetworkInterface.getByName("hme0");  
  2. DatagramChannel dc = DatagramChannel.open(StandardProtocolFamily.INET)  
  3.          .setOption(StandardSocketOption.SO_REUSEADDR, true)  
  4.          .bind(new InetSocketAddress(5000))  
  5.          .setOption(StandardSocketOption.IP_MULTICAST_IF, networkInterface);  
  6.  
  7. InetAddress group = InetAddress.getByName("225.4.5.6");  
  8. MembershipKey key = dc.join(group, networkInterface); 

你可以使用以前經常使用的DatagramChannel,但操作方式是多播了,因此你收到的是接口中所有的數據包,你發送的數據包會發到所有組。

NetworkChannel

現在所有網絡通道都實現了新的NetworkChannel接口,你可以輕松綁定套接字管道,設置和查詢套接字選項,此外,套接字選項也被擴展了,因此你可以使用操作系統特定的選項,對于高性能服務器這非常有用。

異步I/O

現在我們介紹最重要的新特性:異步I/O API,從它的名字我們就知道它有什么功能了,這個新的通道為套接字和文件提供了異步操作。當然,所有操作都是非阻塞的,但對所有異步通道,你也可以執行阻塞操作,所有異步I/O操作都有下列兩種形式中的一種:

◆第一個返回java.util.concurrent.Future,代表等待結果,你可以使用Future特性等待I/O操作結束;

◆第二個是使用CompletionHandler創建的,當操作結束時,如回調系統,調用這個處理程序。

下面是它們的一些例子,首先來看看使用Future的例子:

  1. AsynchronousFileChannel channel = AsynchronousFileChannel.open(Paths.get("Path to file"));  
  2. ByteBuffer buffer = ByteBuffer.allocate(capacity);  
  3. Future result = channel.read(buffer, 100); //Read capacity bytes from the file starting at position 100  
  4. boolean done = result.isDone(); //Indicate if the result is already terminated 

你也可以等待結束:

  1. int bytesRead = result.get(); 
  2.  

或等待超時:

  1. int bytesRead = result.get(10, TimeUnit.SECONDS); //Wait at most 10 seconds on the result 
  2.  

再來看看使用CompletionHandler的例子:

  1. Future result = channel.read(buffer, 100, null, new CompletionHandler(){  
  2.     public void completed(Integer result, Object attachement){  
  3.         //Compute the result  
  4.     }  
  5.  
  6.     public void failed(Throwable exception, Object attachement){  
  7.         //Answer to the fail  
  8.     }  
  9. }); 

正如你所看到的,你可以給操作一個附件,在操作末尾給CompletionHandler,當然,你可以把null當作一個附件提供,你可以傳遞任何你想傳遞的,如用于AsynchronousSocketChannel的Connection,或用于讀操作的ByteBuffer。

  1. Future result = channel.read(buffer, 100, buffer, new CompletionHandler(){  
  2.     public void completed(Integer result, ByteBuffer buffer){  
  3.         //Compute the result  
  4.     }  
  5.  
  6.     public void failed(Throwable exception, ByteBuffer buffer){  
  7.         //Answer to the fail  
  8.     }  
  9. }); 

正如你所看到的,CompletionHandle也提供Future元素表示等待結果,因此你可以合并這兩個格式。下面是NIO.2中的所有異步通道:

◆AsynchronousFileChannel:讀寫文件的異步通道,這個通道沒有全局位置,因此每個讀寫操作都需要一個位置,你可以使用不同的線程同時訪問文件的不同部分,當你打開這個通道時,必須指定READ或WRITE選項;

◆AsynchronousSocketChannel:用于套接字的一個簡單異步通道,連接、讀/寫、分散/聚集方法全都是異步的,讀/寫方法支持超時;

◆AsynchronousServerSocketChannel:用于ServerSocket的異步通道,accept()方法是異步的,當連接被接受時,調用CompletionHandler,這種連接的結果是一個AsynchronousSocketChannel;

◆AsynchronousDatagramChannel:用于數據報套接字的通道,讀/寫(連接)和接收/發送(無連接)方法是異步的。

#p#

分組

當你使用AsynchronousChannels時,有線程調用完整的處理程序,這些線程被綁定到一個AsynchronousChannelGroup組,這個組包含一個線程池,它封裝了所有線程共享的資源,你可以使用線程池來調用這些組,AsynchronousFileChannel可以使用它自己的組創建,將ExecutorService作為一個參數傳遞給open()方法,在open方法中,通道是使用AsynchronousChannelGroup創建的,如果你不給它一個組,或傳遞一個NULL,它就會使用默認組。通道被認為是屬于組的,因此,如果組關閉了,通道也就關閉了。你可以使用ThreadFactory創建一個組:

  1. ThreadFactory myThreadFactory = Executors.defaultThreadFactory();  
  2. AsynchronousChannelGroup channelGroup = AsynchronousChannelGroup.withFixedThreadPool(25, threadFactory); 
  3.  

或使用一個ExecutorService:

  1. ExecutorService service = Executors.newFixedThreadPool(25);  
  2. AsynchronousChannelGroup channelGroup = AsynchronousChannelGroup.withThreadPool(service);
  3.  

而且你可以很容易地使用它:

  1. AsynchronousSocketChannel socketChannel = AsynchronousSocketChannel.open(channelGroup); 
  2.  

你可以使用在組上使用shutdown()方法關閉組,關閉之后,你就不能使用這個組創建更多的通道,當所有通道關閉后,組也終止了,處理程序結束,資源也釋放了。

當你使用任何類型的池和CompletionHandler時,你必須要注意一點,不要在CompletionHandler內使用阻塞或長時間操作,如果所有線程都被阻塞,整個應用程序都會被阻塞掉。如果你有自定義或緩存的線程池,它會使隊列無限制地增長,最終導致OutOfMemoryError。

我想我把新的異步I/O API涵蓋的內容講得差不多了,當然這不是一兩句話可以說清楚的,也不是每一個人都會使用到它們,但在某些時候它確實很有用,Java支持這種I/O操作終歸是一件好事。如果我的代碼中有什么錯誤我表示道歉,因為我也是剛剛才接觸。

原文名:Java 7 : New I/O features (Asynchronous operations, multicasting, random access) with JSR 203 (NIO.2)

原文出處:www.baptiste-wicht.com/2010/04/java-7-new-io-features-asynchronous-operations-multicasting-random-access-with-jsr-203-nio-2/

【編輯推薦】

  1. 再探Java 7:最新特性更新、代碼示例及性能測試
  2. Java 7的第一類函數:學習閉包的使用
  3. Java 7已經完成的七大新功能預覽
  4. Java 7新功能代碼范例
  5. 開發熱點周報:Java 7閉包引爭議 PDC大會精彩紛呈
責任編輯:王曉東 來源: IT168
相關推薦

2009-12-16 10:41:37

Ruby隨機存取文件

2009-05-25 15:17:40

C++隨機存取文件

2009-11-26 14:16:06

Java 7

2018-03-28 08:52:53

阻塞非阻塞I

2021-05-20 10:36:30

Chrome瀏覽器系統技巧

2015-08-10 14:39:46

Java 操作建議

2010-03-17 15:22:14

2010-06-29 09:23:09

JDK 7I|ONIO.2

2011-08-25 09:56:49

數據訪問

2012-07-10 10:08:32

紅帽RHEL 7

2009-08-31 18:40:01

Java 7新功能

2018-11-05 11:20:54

緩沖IO

2009-09-22 15:15:02

Windows 7新功文件搜索Windows Sea

2009-09-22 15:24:20

Windows 7新功文件管理

2009-02-18 21:16:16

2013-05-28 10:08:41

IO輸出

2015-07-21 15:56:41

虛擬化存儲方式數據中心

2011-04-20 09:20:00

Windows 8

2009-08-21 18:59:53

遠程管理Windows

2009-07-07 08:46:11

微軟Windows 7新功能
點贊
收藏

51CTO技術棧公眾號

国产精品久久久久久久久图文区 | 亚洲中文字幕无码一区二区三区| 欧美啪啪一区| 日韩一级免费在线观看| 日本高清免费不卡视频| 精品人人人人| 日韩免费三级| 蜜臀久久99精品久久久久久9| 久久精品国产精品亚洲色婷婷| 欧美va亚洲va在线观看蝴蝶网| 加勒比一区二区三区在线| 久久久免费观看| 伊人久久大香线| 国产嫩草一区二区三区在线观看| 久久青草欧美一区二区三区| 久久一区二区精品| 国产精品卡一卡二卡三| 波多野结衣中文在线| 国产精品激情自拍| 91老司机福利 在线| 黄色美女视频在线观看| 国产免费观看久久黄| 欧美激情一区在线观看| 毛片在线网址| 国产精品扒开腿做| 久久麻豆一区二区| av中文字幕在线观看第一页 | 亚洲第一偷拍| 成人黄动漫网站| 日韩欧美成人一区二区| 国产精品麻豆| 日本成人黄色| 国产一区999| a在线视频v视频| 久久久免费视频网站| 全亚洲最色的网站在线观看| 亚洲人成网站色在线观看| 欧美男女爱爱视频| 色综合男人天堂| 久久久91精品国产一区二区精品 | 国产精品一卡| 黄色网在线免费看| 91在线|亚洲| 色婷婷av久久久久久久| 日韩欧美大片| 在线激情av| 国产高清视频一区| 日本一区二区久久精品| 欧美在线免费观看亚洲| 国产美女一区| 三级外国片在线观看视频| 欧美一级大片在线观看| 青青草国产精品97视觉盛宴| 欧美黄色网视频| 在线视频国产三级| 日日噜噜噜噜夜夜爽亚洲精品| 亚洲性无码av在线| 久久综合国产精品| 五月开心六月丁香综合色啪| 成人在线app| 伊人久久青草| 久久精品国产99国产精品澳门| 久久网这里都是精品| 国产在视频一区二区三区吞精| 国产午夜伦鲁鲁| 欧美高清在线播放| 国产精品视频一区国模私拍| 午夜在线不卡| 欧美在线观看网址综合| 国产精一区二区三区| 69久久夜色| 欧美男女交配视频| 神马影院我不卡| 欧美美女黄色网| 日本乱人伦aⅴ精品| 免费久久久久久久久| 看片一区二区| 91网页版在线登录入口| 青草视频在线观看视频| av一二三不卡影片| re久久精品视频| aa级大片免费在线观看| 中文字幕国内自拍| 国产成人成网站在线播放青青| 亚洲成人激情在线观看| 91亚洲精品久久久蜜桃| 久久人人爽人人爽人人片av不| 亚洲欧美一区二区三区| 男人的天堂狠狠干| 亚洲视频欧洲视频| 亚洲黄色在线看| 精品国产乱码久久久久久免费 | 欧美二区在线视频| 国内精品视频免费| 高清欧美性猛交xxxx黑人猛交| 一区二区国产盗摄色噜噜| 石原莉奈在线亚洲三区| 久久影院资源站| 最新国产拍偷乱拍精品| 国产成人免费av在线| 久久精品人人做| 欧美色欧美亚洲高清在线视频| 欧美日韩国产首页在线观看| 欧美精品99久久久**| 日韩电影中文字幕在线| 欧美成人精品xxx| 5g影院天天爽成人免费下载| 欧美自拍资源在线| 在线观看日韩片| 五月天国产一区| 久久亚洲精品欧美| 国产精品国产三级国产aⅴ浪潮| 欧美激情精品久久久| 中文字幕九色91在线| 亚洲欧美日韩国产一区二区三区| 伊人成综合网| 亚洲一区二区高清视频| 国产精品久久久久久久免费大片| 欧美精品xxx| 久久国产精品色av免费看| 91精品国产一区| 欧美天堂在线观看| 国产精品久久777777| 久久精品国产第一区二区三区| 久久精品观看| 国产91露脸合集magnet| 国产欧美精品国产国产专区| 国产成人av电影免费在线观看| 亚洲五月综合| 九一国产精品| 视频一区欧美精品| 亚洲欧美激情一区二区| 欧洲精品视频在线观看| 日韩高清中文字幕| 日韩电影免费在线观看中文字幕| 欧美精品一区二区三区蜜臀| 日韩精品资源二区在线| 亚洲天堂av网| 国产精品久久久久7777| 国产1区在线| 日本欧美高清| 国产又黄又大久久| 国产成人av电影在线观看| 国产一区二区三区香蕉| 成人av资源在线| 精品久久久久久久久久久久久久久| 成人免费福利在线| 熟妇人妻无乱码中文字幕真矢织江| 久草综合在线观看| 精品少妇在线视频| av大大超碰在线| 亚洲午夜精品一区 二区 三区| 国产精品毛片大码女人 | 欧美日韩一区自拍| 黄色成人在线播放| 欧美极品在线播放| 九一国产精品视频| 欧美精品videosex| 一区二区三区福利| 亚洲成年人在线播放| 亚洲欧美日韩不卡一区二区三区| 电影在线观看一区| av午夜精品一区二区三区| 色综合久久综合中文综合网| 欧美日韩国产高清一区| 91精品欧美福利在线观看| 欧美一级日韩免费不卡| 亚洲国产成人久久综合| 欧美大尺度在线观看| 国产精品福利视频| 久久久久欧美| 美女做暖暖视频免费在线观看全部网址91 | 好吊妞国产欧美日韩免费观看网站 | 九色porny在线观看| 亚洲日韩中文字幕一区| 久久这里都是精品| 91久久精品久久国产性色也91| 黄黄视频在线观看| 91在线直播| 老色鬼久久亚洲一区二区| 91豆花精品一区| jlzzjlzz欧美大全| 欧美激情久久久久久久久久久| 尤物av一区二区| 欧美极品少妇xxxxⅹ免费视频 | 欧美日本高清视频在线观看| www.av毛片| 亚洲91网站| 中文字幕佐山爱一区二区免费| 国产一区二区丝袜高跟鞋图片| 国内欧美日韩| 中文字幕中文乱码欧美一区二区| 国产69精品久久久久9| 日本高清视频网站www| 亚洲视频电影在线| 日韩欧美三级在线| 欧美久久在线观看| 日本一区二区三区视频| 黄色91在线观看| 色乱码一区二区三区熟女|