Flyingis

          Talking and thinking freely !
          Flying in the world of GIS !
          隨筆 - 156, 文章 - 16, 評論 - 589, 引用 - 0
          數據加載中……

          文件加鎖基礎

          作者:Flyingis

              文件加鎖是
          JDK1.4引入的一種機制,它允許我們同步訪問某個作為共享資源的文件。競爭同一文件的兩個線程可能在不同的Java虛擬機上,或者一個是Java線程,另一個是操作系統中的某個本地線程。文件鎖對其他的操作系統進程是可見的,因為Java的文件加鎖直接映射到了本地操作系統的加鎖工具。

          通過對FileChannel調用tryLock()lock(),就可以獲得整個文件的FileLock。特殊的是,SocketChannel/DatagramChannel/ServerSocketChannel不需要加鎖,因為它們是從單進程實體繼承而來,我們通常不在兩個進程之間共享網絡的socket

          tryLock()是非阻塞式的,它設法獲取鎖,但如果不能獲得,例如因為其他一些進程已經持有相同的鎖,而且不共享時,它將直接從方法調用返回。

          lock()是阻塞式的,它要阻塞進程直到鎖可以獲得,或調用lock()的線程中斷,或調用lock()的通道關閉。

          對獨占鎖和共享鎖的支持必須由底層的操作系統提供。鎖的類型可以通過FileLock.isShared()進行查詢。另外,我們不能獲取緩沖器上的鎖,只能是通道上的。

          文件加鎖的實際應用之一:文件映射通常應用于大型的文件,我們可能需要對巨大的文件進行部分加鎖,以便其他的進程可以修改文件中未被加鎖的部分,數據庫就是如此,使得多用戶可以訪問到未加鎖的部分數據。其他的應用還知之甚少。

          posted on 2006-01-07 13:50 Flyingis 閱讀(3925) 評論(2)  編輯  收藏 所屬分類: JavaSE

          評論

          # re: 文件加鎖基礎  回復  更多評論   

          進程之間非常獨立,很少有可以共享的東西,只有找到可以在進程間共享的東西,才能實現進程的互斥: 文件鎖就是一個典型的應用。
          2006-01-07 23:57 | 胡子魚

          # re: 文件加鎖基礎  回復  更多評論   

          jdk這個不支持不同虛擬機之間加鎖的。進程間互斥用不了的。
          2006-01-22 13:04 | Lock
          主站蜘蛛池模板: 四平市| 桦甸市| 故城县| 军事| 敖汉旗| 苏尼特左旗| 兰坪| 秦安县| 鄂托克前旗| 邵阳县| 延寿县| 乐平市| 永安市| 包头市| 马鞍山市| 道孚县| 乌苏市| 泽州县| 抚顺县| 望江县| 黎城县| 建瓯市| 卢湾区| 邢台市| 班戈县| 蓬莱市| 密云县| 革吉县| 泸溪县| 东宁县| 涞水县| 赤壁市| 汤原县| 贵阳市| 襄垣县| 胶州市| 射洪县| 工布江达县| 台中市| 静安区| 九台市|