向左走,向右走。。。
          永遠(yuǎn)不回頭
          posts - 16,comments - 17,trackbacks - 0
          在JDK1.4.2中加入了對(duì)NIO的支持,掌握其中的Selector個(gè)人認(rèn)為是能實(shí)現(xiàn)好NIO的關(guān)鍵。

          Selector是用來獲取注冊(cè)在其中的channel的相關(guān)事件的發(fā)生,也就是accept,read和write。selector中有3個(gè)key set。

          key set:包含代表所有在其中注冊(cè)的channel,可以通過selector.keys()得到。
          selected-key set:包含所有被檢測(cè)到有關(guān)注的操作已經(jīng)就緒的key,通過selector.selectedKeys得到。
          cancelled-key set:包含所有已經(jīng)被cancel,但是還沒有channel還沒有deregister的key,這個(gè)集合是不能直接被訪問的。

          key通過調(diào)用channel的register方法被加入到key set中。被取消的key在select的時(shí)候會(huì)被從相應(yīng)的key set中移除。

          key set自身是不可以直接進(jìn)行修改的。 無論是通過調(diào)用channel的close方法還是調(diào)用key的cancel方法,key都會(huì)被放置到canceled-key set中。取消的key會(huì)將其channel在下一次select時(shí)將注冊(cè)撤銷,同時(shí)將key從所有的key set中移除。

          key在執(zhí)行select操作時(shí)被加入到selected-key set中。在selected-key set中的key可以通過調(diào)用iterator的remove方法,將其從selected-key set中移除,不能通過其他的辦法將其從selected-key set中移除。

          通過selector的3個(gè)方法select(阻塞選擇,直到有關(guān)心的事件發(fā)生時(shí)退出阻塞),selectNow(不阻塞選擇),select(long)(指定超時(shí)選擇,超時(shí)到達(dá)或者有關(guān)心事件發(fā)生時(shí)退出阻塞),來獲取關(guān)心事件的發(fā)生。其執(zhí)行步驟分為以下3步:

          1、將存在于canceled-key set中的key從所有的key set中移除,撤銷注冊(cè)的channel,清空canceled-key set。
          2、地層操作系統(tǒng)檢查是否有關(guān)心的事件發(fā)生,當(dāng)有關(guān)心的事件發(fā)生時(shí),首先檢查channel的key是否已經(jīng)存在于selected-key set中,如果不存在,則將其加入到selected-key set中去,同時(shí)修改key的ready-operation set來表明當(dāng)前ready的操作,而以前存在于ready-operation set中的信息會(huì)被刪除。如果對(duì)應(yīng)的key已經(jīng)存在于selected-key set中,這直接修改其ready-operation set來表明當(dāng)前ready的操作,刪除原來ready-operation set中的信息。
          3、如果在第二步中有加入到canceled-key set中的key,在這一步會(huì)執(zhí)行第一步的操作。

          selector自身是線程安全的,而他的key set卻不是。在一次選擇發(fā)生的過程中,對(duì)于key的關(guān)心事件的修改要等到下一次select的時(shí)候才會(huì)生效。 另外,key和其代表的channel有可能在任何時(shí)候被cancel和close。因此存在于key set中的key并不代表其key是有效的,也不代表其channel是open的。如果key有可能被其他的線程取消或關(guān)閉channel,程序必須小 心的同步檢查這些條件。

          阻塞了的select可以通過調(diào)用selector的wakeup方法來喚醒。
          posted on 2005-04-26 10:06 非飛 閱讀(17402) 評(píng)論(3)  編輯  收藏 所屬分類: JAVA 相關(guān)技術(shù)

          FeedBack:
          # re: NIO中Selector的工作原理
          2005-04-29 15:50 | idior
          # re: NIO中Selector的工作原理
          2005-12-26 15:40 | zhangwei
          selector.selectedKeys返回是Set(應(yīng)該是集合的意思吧)但為什么返回值是int型匿?jdk上說A selection key contains two operation sets represented as integer values. Each bit of an operation set denotes a category of selectable operations that are supported by the key's channel.它意思是說一個(gè)整數(shù)(8bit)的每一個(gè)bit代表一個(gè)操作么?  回復(fù)  更多評(píng)論
            
          # re: NIO中Selector的工作原理
          2005-12-26 22:19 | zhangwei
          sorry, 我說的是SelectionKey.interestOps  回復(fù)  更多評(píng)論
            
          主站蜘蛛池模板: 陇川县| 桂林市| 边坝县| 宁都县| 太谷县| 西藏| 石渠县| 辽宁省| 蒲城县| 安西县| 金寨县| 郯城县| 萨嘎县| 赞皇县| 卓尼县| 鹤山市| 会东县| 永顺县| 华安县| 视频| 鹤庆县| 宜城市| 朝阳县| 阿拉尔市| 绵阳市| 上犹县| 皮山县| 汉川市| 宜宾县| 广饶县| 大新县| 五寨县| 汝阳县| 喀什市| 赤城县| 盐山县| 五原县| 庆安县| 盖州市| 江源县| 平潭县|