<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12
      代碼改變世界

      細說文件讀寫操作(讀寫鎖)

      2011-11-15 00:20  空逸云  閱讀(8312)  評論(19)    收藏  舉報

      開發過程中,我們玩玩需要大量與文件交互,讀文件,寫文件已成家常便飯,本地運行完美,但一上到投產環境,往往會出現很多令人措手不及的意外,或開發中的煩惱,因此,我對普通的C#文件操作做了一次總結,問題大部分如下:

      1:寫入一些內容到某個文件中,在另一個進程/線程/后續操作中要讀取文件內容的時候報異常,提示 System.IO.IOException: 文件“XXX”正由另一進程使用,因此該進程無法訪問此文件。

      2:在對一個文件進行一些操作后(讀/寫),隨后想追加依然報System.IO.IOException: 文件“XXX”正由另一進程使用,因此該進程無法訪問此文件。次問題與1相似。

      3:對一個文件進行一些操作后,想刪除文件,依然報System.IO.IOException: 文件“XXX”正由另一進程使用,因此該進程無法訪問此文件。

      看到這些,有經驗的同學應該就會說資源沒被釋放掉,但也存在如下可能性。我們對文件的操作非常頻繁,所以寫了特定的操作類/組件來維護文件之間的操作,知道特定的時刻才結束,常見的如日志,隨著程序的啟動便開始寫日志,直到程序關閉。但此中也存在我們需要提供一個特殊的操作(讀/寫/刪除)來操作文件,例如我們需要提供一個日志查看器來查看當前日志或所有日志,這時,便無可避免的發生了以上的問題。

      static void WriteFile(FileMode fileMode, FileAccess fileAccess, FileShare fileShare)
      {
          Console.WriteLine("please input your content.");
          var content = Console.ReadLine();
          FileStream fs = new FileStream(FILEPATH, fileMode, fileAccess, fileShare);
          var buffer = Encoding.Default.GetBytes(content);
          fs.Write(buffer, 0, buffer.Length);
          fs.Flush();
      }
      

      首先,我聲明了一個寫文件方法,并調用它,它將我輸入的內容寫入指定的文件當中。

      WriteFile(FileMode.Create, FileAccess.Write, FileShare.Read);
      Console.ReadKey();
      

      imageimage

      但是,在寫文件操作結束之后,我并沒有釋放掉文件流的資源。所以,此時會對文件造成一個鎖。我嘗試在windows中刪除它。

      image

      很明顯我無法刪除掉這個文件,接下來,我嘗試讀取它。

      static void ReadFile(FileAccess fileAccess, FileShare fileShare)
      {
          FileStream fs = new FileStream(FILEPATH, FileMode.Open, fileAccess, fileShare);
          var buffer = new byte[fs.Length];
          fs.Position = 0;
          fs.Read(buffer, 0, buffer.Length);
          Console.WriteLine(Encoding.Default.GetString(buffer));
      }
      

      我實現了一個讀文件方法,并調用了它。

      WriteFile(FileMode.Create, FileAccess.Write, FileShare.Read);
      ReadFile(FileAccess.Read, FileShare.Read);
      

      一切都很簡單,訪問模式為只讀,這樣應該就不會與上面的寫鎖進行沖突!

      image

      但是,結果并非我們所預想的那樣,為什么會提示無法訪問?回想一下,在前面,我用windows的記事本打開了這個文件,并沒有提示說文件被鎖定,我也的確能訪問,那為何到了程序里就無法訪問了呢?或許,我們應該把重點放在FileModeFileAccessFileShare這三個枚舉身上,說不定就是它們搞的鬼。

      FileMode

      MSDN上的解釋是指定操作系統打開文件的方式,我想這個應該不需要解釋了,大家平時用得比較多了。MSDN的表格也很好的闡述了各個枚舉值的作用,我就不在解釋了。

      FileAccess

      定義用于文件讀取、寫入或讀取/寫入訪問權限的常數。

      image

      這個枚舉也用得比較多了,描述也很通俗易懂,我也不便再解釋了。^_^!

      FileShare

      相信這個枚舉類型大家會比較陌生,甚至有同學見都沒見過(慚愧的是,我也是才認識它沒多久),陌生歸陌生,但它的作用力也是不可低估,只是.Net幫我們把它封裝得比較好,以至于我們一度認為它不是什么重要角色。好吧,進入主題!

      包含用于控制其他 FileStream 對象對同一文件可以具有的訪問類型的常數。這句話是什么意思呢?說實話,我現在看句話還是覺得很糾結,相信很多同學看到也是一頭霧水,沒關系,我們先跳過!

      image

      看它的成員描述,和FileAccess很是相似,那我們就嘗試著來揭開它暫時神秘的面紗吧!

      FileShare.Read

      從字面上的意思,我們可以理解為首先打開一個文件之后(資源未釋放),我們可以再用只讀的方式讀取文件從而不會拋出文件無法訪問的異常。利用剛才實現的方法,可以輕易的再完成這個實驗:

      WriteFile(FileMode.Create, FileAccess.Write, FileShare.Read);
      ReadFile(FileAccess.Read, FileShare.Read);
      

      image

      這是什么回事?不是都設置成已讀了嗎?或許只能在讀文件的時候才能設置為只讀共享。我們再嘗試一下:

      ReadFile(FileAccess.Read, FileShare.Read);
      ReadFile(FileAccess.Read, FileShare.Read);
      

      image

      這次的確是能在第一次沒釋放資源時再讀,那我們再試試能否在設置只讀共享后寫文件:

      ReadFile(FileAccess.Read, FileShare.Read);
      WriteFile(FileMode.Create, FileAccess.Write, FileShare.Read);
      

      image

      首先正確的讀出了文件的內容,但當我嘗試寫入一些內容的時候卻又報錯了。那么,根據以上的實驗,就可以得知這個只讀的共享只有是在連續讀取文件才有效!

      FileShare.Write

      結合Read的經驗,字面上的意思應該可以理解為,只有在寫文件時設置共享方式為Write,隨后才能繼續寫入文件,否則會拋出異常。這里比較好玩的時,設置Write之后,萬能的Window記事本也打不開文件了。

      image

      FileShare.ReadWrite

      有了以上的經驗,從字面上理解,可以認為這個ReadWrite一定是結合了Read和Write的特性。那到底它有什么用呢?上面我們知道,在讀文件設置Read共享能繼續讀而不能寫,在寫文件時設置Write共享則能繼續寫而不能讀,但是當我們設置了寫共享后并想讀取文件時怎么辦?只能先釋放資源再重新加載了嗎?不需要,ReadWrite就是為此而生的。

      WriteFile(FileMode.Create, FileAccess.Write, FileShare.Read);
      ReadFile(FileAccess.Read, FileShare.ReadWrite);
      

      image

      不過這里寫文件的時候并不允許把共享設置成Write,否則讀文件時用ReadWrite則無效(報異常),但都設置為ReadWrite可以。這一定,便可以解決很多日常開發中的煩惱。

      FileShare.None/FileShare.Delete

      有了上面的經驗,相信這兩個你也很容易的就理解了,None則為不允許后續有任何操作,而Delete則是允許你隨后進行刪除操作。

      黑箱子里的內容

      對于文件操作,我們平常使用的比較多的可能是以下幾種:

      File.AppendAllText("......");
      File.AppendAllLines(...);
      File.AppendText(...);
      FileStream fs = new FileStream(path, FileAccess.Write);
      fs.Write(....);
      

      實際上它們也是在內部初始化了FileMode/FileAccess/FileShare,例如File的靜態方法最后都會生成一

      個Stream實例,其中便調用了私有方法

      image

      尾聲

      現在,我們明白了,其實/FileShare就是控制文件流的“訪問權限”,當然,這僅僅是入門的文件操作,自己做了筆記,也希望能給大家帶來幫助,高級篇園子里已經有不少前輩寫了文件讀寫鎖方面的文章,感興趣的同學可有搜索一下,前去觀摩!!

      主站蜘蛛池模板: 国产在线精品福利91香蕉| 欧美激情一区二区三区在线| 极品一区二区三区水蜜桃| 蜜芽久久人人超碰爱香蕉| 亚洲精品综合网二三区| 国产高清在线男人的天堂| 欧美综合婷婷欧美综合五月| 成年女人黄小视频| 亚洲国产精品人人做人人爱| 老司机性色福利精品视频| 正在播放酒店约少妇高潮| 国产精品推荐视频一区二区| 国产激情艳情在线看视频| 中国女人熟毛茸茸A毛片| 精品国产一区二区三区av色诱 | 亚洲av乱码一区二区| 亚洲中文字幕日产无码成人片 | 哈密市| 最新偷拍一区二区三区| 黑人异族巨大巨大巨粗| 成午夜福利人试看120秒| 国产精品国产精品偷麻豆| 伊人精品成人久久综合97| 精品无码国产一区二区三区av| 达日县| 18禁成人免费无码网站| 综合色一色综合久久网| 国产福利免费在线观看| 亚洲色一区二区三区四区| 欧日韩无套内射变态| 国内视频偷拍久久伊人网| 中文字幕亚洲制服在线看| 久久经精品久久精品免费观看| 色综合色综合色综合频道| 一本无码在线观看| 亚洲男人天堂一级黄色片| 国内精品一区二区不卡| 日韩国产精品无码一区二区三区 | 亚洲自在精品网久久一区| 国产无遮挡猛进猛出免费软件| 免费无码va一区二区三区 |