日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#内存映射文件学习总结

發布時間:2025/4/14 C# 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#内存映射文件学习总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

C#內存映射文件學習

http://www.cnblogs.com/flyant/p/4443187.html


內存映射文件是由一個文件到進程地址空間的映射。


? ? ? ? C#提供了允許應用程序把文件映射到一個進程的函(MemoryMappedFile.CreateOrOpen)。內存映射文件與虛擬內存有些類似,通過內存映射文件可以保留一個地址空間的區域,同時將物理存儲器提交給此區域,只是內存文件映射的物理存儲器來自一個已經存在于磁盤上的文件,而非系統的頁文件,而且在對該文件進行操作之前必須首先對文件進行映射,就如同將整個文件從磁盤加載到內存。由此可以看出,使用內存映射文件處理存儲于磁盤上的文件時,將不必再對文件執行I/O操作,這意味著在對文件進行處理時將不必再為文件申請并分配緩存,所有的文件緩存操作均由系統直接管理,由于取消了將文件數據加載到內存、數據從內存到文件的回寫以及釋放內存塊等步驟,使得內存映射文件在處理大數據量的文件時能起到相當重要的作用。另外,實際工程中的系統往往需要在多個進程之間共享數據,如果數據量小,處理方法是靈活多變的,如果共享數據容量巨大,那么就需要借助于內存映射文件來進行。實際上,內存映射文件正是解決本地多個進程間數據共享的最有效方法。


? ? ? ? 共享內存是內存映射文件的一種特殊情況,內存映射的是一塊內存,而非磁盤上的文件。共享內存的主語是進程(Process),操作系統默認會給每一個進程分配一個內存空間,每一個進程只允許訪問操作系統分配給它的哪一段內存,而不能訪問其他進程的。而有時候需要在不同進程之間訪問同一段內存,怎么辦呢?操作系統給出了創建訪問共享內存的API,需要共享內存的進程可以通過這一組定義好的API來訪問多個進程之間共有的內存,各個進程訪問這一段內存就像訪問一個硬盤上的文件一樣。而.Net 4.0中引入了System.IO.MemoryMappedFiles命名空間,這個命名空間的類對windows 共享內存相關API做了封裝,使.Net程序員可以更方便的使用內存映射文件。


內存映射文件實現進程間通訊


? ? ? ? 內存映射文件是實現進程通訊的又一種方法,我們可以通過共享剪貼板、共享物理文件來實現進程間的數據共享,這里我們還可以通過內存映射文件來實現共享,這樣,文件內的數據就可以用內存讀/寫指令來訪問,而不是用ReadFile和WriteFile這樣的I/O系統函數,從而提高了文件存取速度。這種方式更加快捷高效,最適用于需要讀取文件并且對文件內包含的信息做語法分析的應用程序,如:對輸入文件進行語法分析的彩色語法編輯器,編譯器等。這種數據共享是讓兩個或多個進程映射同一文件映射對象的視圖,即它們在共享同一物理存儲頁。這樣,當一個進程向內存映射文件的一個視圖寫入數據時,其他的進程立即在自己的視圖中看到變化。


注意:


? ? ? ? 對文件映射對象要使用同一名字。


? ? ? ? 是讓兩個或多個進程映射同一文件映射對象的視圖,即它們在共享同一物理存儲頁。這樣,當一個進程向內存映射文件的一個視圖寫入數據時,其他的進程立即在自己的視圖中看到變化。但要注意,對文件映射對象要使用同一名字。


?內存映射文件使用實例:


1. ? ? ?在同一進程內同時讀寫同一內存映射文件


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.IO.MemoryMappedFiles;


namespace UseMMFInProcess
{
? ? public partial class frmMain : Form
? ? {
? ? ? ? public frmMain()
? ? ? ? {
? ? ? ? ? ? InitializeComponent();
? ? ? ? ? ? CreateMemoryMapFile();
? ? ? ? }
? ? ? ? private const int FILE_SIZE = 512;
? ? ? ? /// <summary>
? ? ? ? /// 引用內存映射文件
? ? ? ? /// </summary>
? ? ? ? private MemoryMappedFile memoryFile = null;
? ? ? ? /// <summary>
? ? ? ? /// 用于訪問內存映射文件的存取對象
? ? ? ? /// </summary>
? ? ? ? private MemoryMappedViewAccessor accessor1, accessor2,accessor;
? ? ? ? /// <summary>
? ? ? ? /// 創建內存映射文件
? ? ? ? /// </summary>
? ? ? ? private void CreateMemoryMapFile()
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? { ? ??
? ? ? ? ? ? ? ? memoryFile = MemoryMappedFile.CreateFromFile("MyFile.dat", FileMode.OpenOrCreate, "MyFile", FILE_SIZE); ? ? ? ? ? ? ??
? ? ? ? ? ? ? ? //訪問文件前半段
? ? ? ? ? ? ? ? accessor1 = memoryFile.CreateViewAccessor(0, FILE_SIZE / 2); ? ? ? ? ? ?
? ? ? ? ? ? ? ? //訪問文件后半段
? ? ? ? ? ? ? ? accessor2 = memoryFile.CreateViewAccessor(FILE_SIZE / 2, FILE_SIZE / 2); ? ? ? ? ? ? ?
? ? ? ? ? ? ? ? //訪問全部文件
? ? ? ? ? ? ? ? accessor = memoryFile.CreateViewAccessor();
? ? ? ? ? ? ? ? //InitFileContent();
? ? ? ? ? ? ? ? lblInfo.Text = "內存文件創建成功";
? ? ? ? ? ? ? ? ShowFileContents();
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? lblInfo.Text = ex.Message;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? /// <summary>
? ? ? ? /// 關閉并釋放資源
? ? ? ? /// </summary>
? ? ? ? private void DisposeMemoryMapFile()
? ? ? ? {
? ? ? ? ? ? if (accessor1 != null)
? ? ? ? ? ? ? ? accessor1.Dispose();
? ? ? ? ? ? if (accessor2 != null)
? ? ? ? ? ? ? ? accessor2.Dispose();
? ? ? ? ? ? if (memoryFile != null)
? ? ? ? ? ? ? ? memoryFile.Dispose();
? ? ? ? }


? ? ? ? private void frmMain_FormClosing(object sender, FormClosingEventArgs e)
? ? ? ? {
? ? ? ? ? ? DisposeMemoryMapFile();
? ? ? ? }


? ? ? ? private void btnWrite1_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? if (textBox1.Text.Length == 0)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? lblInfo.Text = "請輸入一個字符";
? ? ? ? ? ? ? ? return;
? ? ? ? ? ? }
? ? ? ? ? ? char[] chs = textBox1.Text.ToCharArray();
? ? ? ? ? ? char ch = chs[0];
? ? ? ? ? ?
? ? ? ? ? ? for (int i = 0; i < FILE_SIZE / 2; i += 2)
? ? ? ? ? ? ? ? accessor1.Write(i, ch);
? ? ? ? ? ??
? ? ? ? ? ? lblInfo.Text = "字符“" + ch + "”已寫到文件前半部份";
? ? ? ? ? ? ShowFileContents();
? ? ? ? }


? ? ? ? private void btnShow_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? ShowFileContents();
? ? ? ? }


? ? ? ? /// <summary>
? ? ? ? /// 初始化文件內容為可視的字符“0”
? ? ? ? /// </summary>
? ? ? ? private void InitFileContent()
? ? ? ? {
? ? ? ? ? ? for (int i = 0; i < FILE_SIZE; i += 2)?
? ? ? ? ? ? ? ? accessor.Write(i,'0');
? ? ? ? }
? ? ? ? /// <summary>
? ? ? ? /// 顯示文件內容
? ? ? ? /// </summary>
? ? ? ? private void ShowFileContents()
? ? ? ? {
? ? ? ? ? ? StringBuilder sb = new StringBuilder(FILE_SIZE);
? ? ? ? ? ? sb.Append("上半段內容:\n");


? ? ? ? ? ? int j = 0;
? ? ? ? ? ? for (int i = 0; i < FILE_SIZE / 2; i += 2)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? sb.Append("\t");
? ? ? ? ? ? ? ? char ch = accessor.ReadChar(i);
? ? ? ? ? ? ? ? sb.Append(j);
? ? ? ? ? ? ? ? sb.Append(":");
? ? ? ? ? ? ? ? sb.Append(ch);
? ? ? ? ? ? ? ? j++;
? ? ? ? ? ? }
? ? ? ? ? ? sb.Append("\n下半段內容:\n");


? ? ? ? ? ? for (int i = FILE_SIZE / 2; i < FILE_SIZE; i += 2)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? sb.Append("\t");
? ? ? ? ? ? ? ? char ch = accessor.ReadChar(i);
? ? ? ? ? ? ? ? sb.Append(j);
? ? ? ? ? ? ? ? sb.Append(":");
? ? ? ? ? ? ? ? sb.Append(ch);
? ? ? ? ? ? ? ? j++;
? ? ? ? ? ? }
? ? ? ? ? ? richTextBox1.Text = sb.ToString();
? ? ? ? }


? ? ? ? private void btnWrite2_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? if (textBox2.Text.Length == 0)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? lblInfo.Text = "請輸入一個字符";
? ? ? ? ? ? ? ? return;
? ? ? ? ? ? }
? ? ? ? ? ? char[] chs = textBox2.Text.ToCharArray();
? ? ? ? ? ? char ch = chs[0];


? ? ? ? ? ? for (int i = 0; i < FILE_SIZE / 2; i += 2)
? ? ? ? ? ? ? ? accessor2.Write(i, ch);
? ? ? ? ? ? lblInfo.Text = "字符“" + ch + "”已寫到文件后半部份";
? ? ? ? ? ? ShowFileContents();
? ? ? ? }
? ? }
}


2. ? ? ?使用內存映射文件在進程間傳送值類型數據


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;


namespace UseMMFBetweenProcess
{
? ? /// <summary>
? ? /// 要共享的數據結構,注意,其成員不能是引用類型
? ? /// </summary>
? ? public struct MyStructure
? ? {
? ? ? ? public int IntValue
? ? ? ? {
? ? ? ? ? ? get;
? ? ? ? ? ? set;
? ? ? ? }
? ? ? ? public float FloatValue
? ? ? ? {
? ? ? ? ? ? get;
? ? ? ? ? ? set;
? ? ? ? }?
? ? }?
}


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO.MemoryMappedFiles;
using System.IO;


namespace UseMMFBetweenProcess
{
? ? public partial class frmMain : Form
? ? {
? ? ? ? public frmMain()
? ? ? ? {
? ? ? ? ? ? InitializeComponent();
? ? ? ? ? ? InitMemoryMappedFile();
? ? ? ? }


? ? ? ? /// <summary>
? ? ? ? /// 內存映射文件的容量
? ? ? ? /// </summary>
? ? ? ? private const int FileSize = 1024 * 1024;
? ? ? ? private MemoryMappedFile file = null;
? ? ? ? private MemoryMappedViewAccessor accessor = null;


? ? ? ? /// <summary>
? ? ? ? /// 初始化內存映射文件
? ? ? ? /// </summary>
? ? ? ? private void InitMemoryMappedFile()
? ? ? ? {
? ? ? ? ? ? file = MemoryMappedFile.CreateOrOpen("UseMMFBetweenProcess", FileSize);
? ? ? ? ? ? accessor = file.CreateViewAccessor();
? ? ? ? ? ? lblInfo.Text = "內存文件創建或連接成功"; ? ? ? ??
? ? ? ? }


? ? ? ? /// <summary>
? ? ? ? /// 要共享的數據對象
? ? ? ? /// </summary>
? ? ? ? private MyStructure data;


? ? ? ? /// <summary>
? ? ? ? /// 顯示數據到窗體上
? ? ? ? /// </summary>
? ? ? ? private void ShowData()
? ? ? ? {
? ? ? ? ? ? textBox1.Text = data.IntValue.ToString();
? ? ? ? ? ? textBox2.Text = data.FloatValue.ToString();
? ? ? ? }


? ? ? ? /// <summary>
? ? ? ? /// 根據用戶輸入更新數據
? ? ? ? /// </summary>
? ? ? ? private void UpdateData()
? ? ? ? {
? ? ? ? ? ? data.IntValue = int.Parse(textBox1.Text);
? ? ? ? ? ? data.FloatValue = float.Parse(textBox2.Text);
? ? ? ? }


? ? ? ? private void btnSave_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? UpdateData();
? ? ? ? ? ? ? ? accessor.Write<MyStructure>(0, ref data);
? ? ? ? ? ? ? ? lblInfo.Text = "數據已經保存到內存文件中";
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? lblInfo.Text = ex.Message;
? ? ? ? ? ? }
? ? ? ? }


? ? ? ? private void btnLoad_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? accessor.Read<MyStructure>(0, out data);
? ? ? ? ? ? ShowData();
? ? ? ? ? ? lblInfo.Text = "成功從內存文件中提取了數據";
? ? ? ? }


? ? ? ? private void frmMain_FormClosing(object sender, FormClosingEventArgs e)
? ? ? ? {
? ? ? ? ? ? if (accessor != null)
? ? ? ? ? ? ? ? accessor.Dispose();
? ? ? ? ? ? if (file != null)
? ? ? ? ? ? ? ? file.Dispose();
? ? ? ? }
? ? }
}


3. ? ? ?利用序列化技術通過內存映射文件實現進程通訊


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.IO.MemoryMappedFiles;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Formatters.Binary;


namespace UseMMFBetweenProcess2
{
? ? public partial class frmMain : Form
? ? {
? ? ? ? public frmMain()
? ? ? ? {
? ? ? ? ? ? InitializeComponent();
? ? ? ? ? ? InitMemoryMappedFile();
? ? ? ? }
? ? ? ?
? ? ? ? /// <summary>
? ? ? ? /// 圖片
? ? ? ? /// </summary>
? ? ? ? private Image bmp
? ? ? ? {
? ? ? ? ? ? get
? ? ? ? ? ? {
? ? ? ? ? ? ? ? return pictureBox1.Image;
? ? ? ? ? ? }
? ? ? ? ? ? set
? ? ? ? ? ? {
? ? ? ? ? ? ? ? pictureBox1.Image = value;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ?
? ? ? ?/// <summary>
? ? ? ?/// 圖片說明
? ? ? ?/// </summary>
? ? ? ? private string info
? ? ? ? {
? ? ? ? ? ? get
? ? ? ? ? ? {
? ? ? ? ? ? ? ? return txtImageInfo.Text;
? ? ? ? ? ? }
? ? ? ? ? ? set
? ? ? ? ? ? {
? ? ? ? ? ? ? ? txtImageInfo.Text = value;
? ? ? ? ? ? }
? ? ? ? }


? ? ? ? private MemoryMappedFile memoryFile = null;


? ? ? ? private MemoryMappedViewStream stream = null;


? ? ? ? /// <summary>
? ? ? ? /// 最大容量:10M
? ? ? ? /// </summary>
? ? ? ? private const int FileSize = 1024 * 1024 * 10; ?


? ? ? ? /// <summary>
? ? ? ? /// 創建內存映射文件,獲取其讀寫流
? ? ? ? /// </summary>
? ? ? ? private void InitMemoryMappedFile()
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? memoryFile = MemoryMappedFile.CreateOrOpen("UseMMFBetweenProcess2", FileSize);
? ? ? ? ? ? stream = memoryFile.CreateViewStream();
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex )
? ? ? ? ? ? {
? ? ? ? ? ? ? ? MessageBox.Show(ex.Message);
? ? ? ? ? ? ? ? Close();
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? /// <summary>
? ? ? ? /// 釋放相關資源
? ? ? ? /// </summary>
? ? ? ? private void DisposeMemoryMappedFile()
? ? ? ? {
? ? ? ? ? ? if (stream != null)
? ? ? ? ? ? ? ? stream.Close();
? ? ? ? ? ? if (memoryFile != null)
? ? ? ? ? ? ? ? memoryFile.Dispose();
? ? ? ? }


? ? ? ? private void btnLoadPic_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? ChooseImageFile();
? ? ? ? }


? ? ? ? //選擇圖片
? ? ? ? private void ChooseImageFile()
? ? ? ? {
? ? ? ? ? ? if (openFileDialog1.ShowDialog() == DialogResult.OK)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? bmp = new Bitmap(openFileDialog1.FileName);
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? //根據用戶設定的信息創建對象
? ? ? ? private MyPic CreateMyPicObj()
? ? ? ? {
? ? ? ? ? ? MyPic obj = new MyPic();
? ? ? ? ? ? obj.pic = bmp;
? ? ? ? ? ? obj.picInfo = info;
? ? ? ? ? ? return obj;
? ? ? ? }


? ? ? ? /// <summary>
? ? ? ? /// 將MyPic對象保存到內存映射文件中
? ? ? ? /// </summary>
? ? ? ? private void SaveToMMF()
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? MyPic obj = CreateMyPicObj();
? ? ? ? ? ? IFormatter formatter = new BinaryFormatter();
? ? ? ? ? ? stream.Seek(0, SeekOrigin.Begin);
? ? ? ? ? ? formatter.Serialize(stream, obj);
? ? ? ? ? ? MessageBox.Show("對象已保存到內存映射文件中");
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? MessageBox.Show(ex.Message);
? ? ? ? ? ? }
? ? ? ? }


?private void LoadFromMMF()
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ?// CreateMyPicObj();
? ? ? ? ? ? IFormatter formatter = new BinaryFormatter();
? ? ? ? ? ? stream.Seek(0, SeekOrigin.Begin);
? ? ? ? ? ? MyPic obj = ? formatter.Deserialize(stream) as MyPic;
? ? ? ? ? ? if (obj != null)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? bmp = obj.pic;
? ? ? ? ? ? ? ? info = obj.picInfo;
? ? ? ? ? ? }
? ? ? ? ? }
? ? ? ? ? catch (Exception ex)
? ? ? ? ? {
? ? ? ? ? ? ? MessageBox.Show(ex.Message);
? ? ? ? ? }
? ? ? ? }


? ? ? ? private void btnExit_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? Close();
? ? ? ? }


? ? ? ? private void frmMain_FormClosing(object sender, FormClosingEventArgs e)
? ? ? ? {
? ? ? ? ? ? DisposeMemoryMappedFile();
? ? ? ? }


? ? ? ? private void btnSaveToMMF_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? SaveToMMF();
? ? ? ? }


? ? ? ? private void btnLoadFromMMF_Click(object sender, EventArgs e)
? ? ? ? {
? ? ? ? ? ? LoadFromMMF();
? ? ? ? }
? ? }
}
========

C# 用內存映射文件讀取大文件(.txt)

http://www.cnblogs.com/criedshy/archive/2010/06/13/1757826.html
? 網上有好多這類的文章,大部分都是用C/C++寫的,也有部分C#寫的,都思想都是一樣的,調用win32 API。


? 至于什么是內存映射文件,相信還是有好多人不知道是怎么一回事的,我也是偶然看window 核心編程了解到的。


? C# 讀取大文件的方法也是用的用StreamReader一次讀出來,再用MemoryStream放在內存,再用StreamReader一行行的讀出來,速度也挺快的,16M的文本大概也就8秒左右,算起來差不多算快了。不過還是不能滿足大文件(我沒測試)。


string content = string.Empty;


? ? ? ? ? ? ? using (StreamReader sr = new StreamReader(op.FileName))
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? content = sr.ReadToEnd();//一次性讀入內存
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? MemoryStream ms = new MemoryStream(Encoding.GetEncoding("GB2312").GetBytes(content));//放入內存流,以便逐行讀取
? ? ? ? ? ? ? ? long line = 0;
? ? ? ? ? ? ? ? using (StreamReader sr = new StreamReader(ms))
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? while (sr.Peek() > -1)
? ? ? ? ? ? ? ? ? ? {


? ? ? ? ? ? ? ? ? ? ? ? this.richTextBox1.AppendText(sr.ReadLine() + "\r\n");
? ? ? ? ? ? ? ? ? ? ? ? Application.DoEvents();
? ? ? ? ? ? ? ? ? ? }


? ? ? ? ? ? ? ?}


 內存映射文件概述


  內存文件映射也是Windows的一種內存管理方法,提供了一個統一的內存管理特征,使應用程序可以通過內存指針對磁盤上的文件進行訪問,其過程就如同對加載了文件的內存的訪問。通過文件映射這種使磁盤文件的全部或部分內容與進程虛擬地址空間的某個區域建立映射關聯的能力,可以直接對被映射的文件進行訪問,而不必執行文件I/O操作也無需對文件內容進行緩沖處理。內存文件映射的這種特性是非常適合于用來管理大尺寸文件的。


  在使用內存映射文件進行I/O處理時,系統對數據的傳輸按頁面來進行。至于內部的所有內存頁面則是由虛擬內存管理器來負責管理,由其來決定內存頁面何時被分頁到磁盤,哪些頁面應該被釋放以便為其它進程提供空閑空間,以及每個進程可以擁有超出實際分配物理內存之外的多少個頁面空間等等。由于虛擬內存管理器是以一種統一的方式來處理所有磁盤I/O的(以頁面為單位對內存數據進行讀寫),因此這種優化使其有能力以足夠快的速度來處理內存操作。


  使用內存映射文件時所進行的任何實際I/O交互都是在內存中進行并以標準的內存地址形式來訪問。磁盤的周期性分頁也是由操作系統在后臺隱蔽實現的,對應用程序而言是完全透明的。內存映射文件的這種特性在進行大文件的磁盤事務操作時將獲得很高的效益。


  需要說明的是,在系統的正常的分頁操作過程中,內存映射文件并非一成不變的,它將被定期更新。如果系統要使用的頁面目前正被某個內存映射文件所占用,系統將釋放此頁面,如果頁面數據尚未保存,系統將在釋放頁面之前自動完成頁面數據到磁盤的寫入。


  對于使用頁虛擬存儲管理的Windows操作系統,內存映射文件是其內部已有的內存管理組件的一個擴充。由可執行代碼頁面和數據頁面組成的應用程序可根據需要由操作系統來將這些頁面換進或換出內存。如果內存中的某個頁面不再需要,操作系統將撤消此頁面原擁用者對它的控制權,并釋放該頁面以供其它進程使用。只有在該頁面再次成為需求頁面時,才會從磁盤上的可執行文件重新讀入內存。同樣地,當一個進程初始化啟動時,內存的頁面將用來存儲該應用程序的靜態、動態數據,一旦對它們的操作被提交,這些頁面也將被備份至系統的頁面文件,這與可執行文件被用來備份執行代碼頁面的過程是很類似的。圖1展示了代碼頁面和數據頁面在磁盤存儲器上的備份過程:


圖1 進程的代碼頁、數據頁在磁盤存儲器上的備份


  顯然,如果可以采取同一種方式來處理代碼和數據頁面,無疑將會提高程序的執行效率,而內存映射文件的使用恰恰可以滿足此需求。
對大文件的管理


  內存映射文件對象在關閉對象之前并沒有必要撤銷內存映射文件的所有視圖。在對象被釋放之前,所有的臟頁面將自動寫入磁盤。通過 CloseHandle()關閉內存映射文件對象,只是釋放該對象,如果內存映射文件代表的是磁盤文件,那么還需要調用標準文件I/O函數來將其關閉。在處理大文件處理時,內存映射文件將表示出卓越的優勢,只需要消耗極少的物理資源,對系統的影響微乎其微。下面先給出內存映射文件的一般編程流程框圖:


圖2 使用內存映射文件的一般流程


  而在某些特殊行業,經常要面對十幾GB乃至幾十GB容量的巨型文件,而一個32位進程所擁有的虛擬地址空間只有232 = 4GB,顯然不能一次將文件映像全部映射進來。對于這種情況只能依次將大文件的各個部分映射到進程中的一個較小的地址空間。這需要對上面的一般流程進行適當的更改:


  1)映射文件開頭的映像。


  2)對該映像進行訪問。


  3)取消此映像


  4)映射一個從文件中的一個更深的位移開始的新映像。


  5)重復步驟2,直到訪問完全部的文件數據。




? ?下面是用C#寫的代碼,大部分代碼轉自網上,自己在原來的基礎上改了一改。


C#內存映射文件代碼
?
? ? ?經過測試16M的文本4秒可以讀出來。


? ? ?現在是有兩個問題還沒有解決:


1.就是編碼的問題,用Unicode解碼的時候,文件大會很慢,而用ANSI和ASCII就很快。不知道為什么,望知情者告之。


2.怎么知道文件的編碼是什么?用win32 IsTestUnicode只能判斷兩種,而且還不保證是對。
========

c#實現內存映射文件共享內存

http://blog.csdn.net/wangtiewei/article/details/51112668 ?
內存映射文件是利用虛擬內存把文件映射到進程的地址空間中去,在此之后進程操作文件,就像操作進程空間里的地址一樣了,比如使用C語言的 memcpy等內存操作的函數。這種方法能夠很好的應用在需要頻繁處理一個文件或者是一個大文件的場合,這種方式處理IO效率比普通IO效率要高
共享內存是內存映射文件的一種特殊情況,內存映射的是一塊內存,而非磁盤上的文件。共享內存的主語是進程(Process),操作系統默認會給每一 個進程分配一個內存空間,每一個進程只允許訪問操作系統分配給它的哪一段內存,而不能訪問其他進程的。而有時候需要在不同進程之間訪問同一段內存,怎么辦 呢?操作系統給出了創建訪問共享內存的API,需要共享內存的進程可以通過這一組定義好的API來訪問多個進程之間共有的內存,各個進程訪問這一段內存就 像訪問一個硬盤上的文件一樣。而.Net 4.0中引入了System.IO. MemoryMappedFiles命名空間,這個命名空間的類對windows 共享內存相關API做了封裝,使.Net程序員可以更方便的使用內存映射文件。
在C#中使用共享內存。以下App1的代碼讓用戶輸入一行文本到共享內存中;App2不停的刷新控制臺,輸出最新的共享內存內容;App3實現的功能和App2相同,但讀取方法不同。


App1代碼: ?
using System; ?
using System.Collections.Generic;android從資源文件中讀取文件流顯示 ?
using System.Linq; ?
using System.Text; ?
??
using System.IO; ?
??
//引用內存映射文件命名空間 ?
using System.IO.MemoryMappedFiles; ?
??
namespace App1 ?
{ ?
? ? class Program ?
? ? { ?
? ? ? ? static void Main(string[] args) ?
? ? ? ? { ?
? ? ? ? ? ? long capacity = 1<<10<<10; ?
??
? ? ? ? ? ? //創建或者打開共享內存 ?
? ? ? ? ? ? using (var mmf = MemoryMappedFile.CreateOrOpen("testMmf", capacity, MemoryMappedFileAccess.ReadWrite)) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? //通過MemoryMappedFile的CreateViewAccssor方法獲得共享內存的訪問器 ?
? ? ? ? ? ? ? ? var viewAccessor = mmf.CreateViewAccessor(0, capacity); ?
? ? ? ? ? ? ? ? //循環寫入,使在這個進程中可以向共享內存中寫入不同的字符串值 ?
? ? ? ? ? ? ? ? while (true) ?
? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? Console.WriteLine("請輸入一行要寫入共享內存的文字:"); ?
??
? ? ? ? ? ? ? ? ? ? string input = Console.ReadLine(); ?
??
? ? ? ? ? ? ? ? ? ? //向共享內存開始位置寫入字符串的長度 ?
? ? ? ? ? ? ? ? ? ? viewAccessor.Write(0, input.Length); ?
??
? ? ? ? ? ? ? ? ? ? //向共享內存4位置寫入字符 ?
? ? ? ? ? ? ? ? ? ? viewAccessor.WriteArray<char>(4, input.ToArray(), 0, input.Length); ?
? ? ? ? ? ? ? ? } ?
??
? ? ? ? ? ? } ?
? ? ? ? ? ? ??
? ? ? ? } ?
? ? } ?
} ?


App2代碼: ?
using System; ?
using System.Collections.Generic; ?
using System.Linq; ?
using System.Text; ?
using System.Threading; ?
??
//引用使用內存映射文件需要的命名空間 ?
using System.IO.MemoryMappedFiles; ?
??
namespace App2 ?
{ ?
? ? class Program ?
? ? { ?
? ? ? ? static void Main(string[] args) ?
? ? ? ? { ?
? ? ? ? ? ? ? long capacity = 1<<10<<10; ?
??
? ? ? ? ? ? ? using (var mmf = MemoryMappedFile.OpenExisting("testMmf")) ?
? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? MemoryMappedViewAccessor viewAccessor = mmf.CreateViewAccessor(0, capacity); ?
??
? ? ? ? ? ? ? ? ? //循環刷新共享內存字符串的值 ?
? ? ? ? ? ? ? ? ? while (true) ?
? ? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? ? //讀取字符長度 ?
? ? ? ? ? ? ? ? ? ? ? int strLength = viewAccessor.ReadInt32(0); ? ? ? ? ? ? ? ? ? ? ? ?
? ? ? ? ? ? ? ? ? ? ? char[] charsInMMf = new char[strLength]; ?
? ? ? ? ? ? ? ? ? ? ? //讀取字符 ?
? ? ? ? ? ? ? ? ? ? ? viewAccessor.ReadArray<char>(4, charsInMMf, 0, strLength); ?
? ? ? ? ? ? ? ? ? ? ? Console.Clear(); ?
? ? ? ? ? ? ? ? ? ? ? Console.Write(charsInMMf); ?
? ? ? ? ? ? ? ? ? ? ? Console.Write("\r"); ?
? ? ? ? ? ? ? ? ? ? ? Thread.Sleep(200); ?
? ? ? ? ? ? ? ? ? } ?
? ? ? ? ? ? ? } ?
? ? ? ? } ?
? ? } ?
} ?


App3代碼: ?
using System; ?
using System.Collections.Generic; ?
using System.Linq; ?
using System.Text; ?
??
using System.IO.MemoryMappedFiles; ?
using System.IO; ?
??
namespace App3 ?
{ ?
? ? class Program ?
? ? { ?
? ? ? ? static void Main(string[] args) ?
? ? ? ? { ?
? ? ? ? ? ? long capacity = 1 << 10 << 10; ?
? ? ? ? ? ? //打開共享內存 ?
? ? ? ? ? ? using (var mmf = MemoryMappedFile.OpenExisting("testMmf")) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? //使用CreateViewStream方法返回stream實例 ?
? ? ? ? ? ? ? ? using (var mmViewStream = mmf.CreateViewStream(0, capacity)) ?
? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? //這里要制定Unicode編碼否則會出問題 ?
? ? ? ? ? ? ? ? ? ? using (BinaryReader rdr = new BinaryReader(mmViewStream,Encoding.Unicode)) ?
? ? ? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? ? ? while (true) ?
? ? ? ? ? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? ? ? ? ? mmViewStream.Seek(0, SeekOrigin.Begin); ?
??
? ? ? ? ? ? ? ? ? ? ? ? ? ? int length = rdr.ReadInt32(); ?
??
? ? ? ? ? ? ? ? ? ? ? ? ? ? char[] chars = rdr.ReadChars(length); ?
??
? ? ? ? ? ? ? ? ? ? ? ? ? ? Console.Write(chars); ?
? ? ? ? ? ? ? ? ? ? ? ? ? ? Console.Write("\r"); ?
??
? ? ? ? ? ? ? ? ? ? ? ? ? ? System.Threading.Thread.Sleep(200); ?
? ? ? ? ? ? ? ? ? ? ? ? ? ? Console.Clear(); ?
? ? ? ? ? ? ? ? ? ? ? ? } ?
? ? ? ? ? ? ? ? ? ? } ?
? ? ? ? ? ? ? ? } ?
? ? ? ? ? ? } ?
? ? ? ? } ?
? ? } ?
} ?
在讀數據時用了2種方法。
因為在之前很少會用到進程之間的通信,所以此方法只是想初步的認識下。此程序寫的過于簡陋,有很多東西都沒有去判斷。比如說是怎么創建了一個共享內存怎么取刪除它等等。。。
========

用C#實現的內存映射

http://blog.csdn.net/linux7985/article/details/5853358


當文件過大時,無法一次性載入內存時,就需要分次,分段的載入文件


主要是用了以下的WinAPI


LPVOID MapViewOfFile(HANDLE hFileMappingObject,
  DWORD dwDesiredAccess,
  DWORD dwFileOffsetHigh,
  DWORD dwFileOffsetLow,
  DWORD dwNumberOfBytesToMap);
?
  MapViewOfFile() 函數負責把文件數據映射到進程的地址空間,參數hFileMappingObject 為 CreateFileMapping()返回的文件映像對象句柄。參數dwDesiredAccess則再次指定了對文件數據的訪問方式,而且同樣要與 CreateFileMapping()函數所設置的保護屬性相匹配。雖然這里一再對保護屬性進行重復設置看似多余,但卻可以使應用程序能更多的對數據的保護屬性實行有效控制。MapViewOfFile()函數允許全部或部分映射文件,在映射時,需要指定數據文件的偏移地址以及待映射的長度。其中,文件的偏移地址由DWORD型的參數dwFileOffsetHigh和dwFileOffsetLow組成的64位值來指定,而且必須是操作系統的分配粒度的整數倍,對于Windows操作系統,分配粒度固定為64KB。當然,也可以通過如下代碼來動態獲取當前操作系統的分配粒度:


  SYSTEM_INFO sinf;
  GetSystemInfo(&sinf);
  DWORD dwAllocationGranularity = sinf.dwAllocationGranularity;


  參數dwNumberOfBytesToMap指定了數據文件的映射長度,這里需要特別指出的是,對于Windows 9x操作系統,如果MapViewOfFile()無法找到足夠大的區域來存放整個文件映射對象,將返回空值(NULL);但是在Windows 2000下,MapViewOfFile()只需要為必要的視圖找到足夠大的一個區域即可,而無須考慮整個文件映射對象的大小。


由此看出,分頁映射文件時,每頁的起始位置startpos,必須為64K的整數倍。


以下貼出源代碼,防止忘記了


using System; ?
using System.Collections.Generic; ?
using System.Text; ?
using System.Runtime.InteropServices; ?
??
namespace BlueVision.SaYuan.FileMapping ?
{ ?
? ? public class ShareMemory ?
? ? { ?
? ? ? ? [DllImport( "user32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern IntPtr SendMessage( IntPtr hWnd, int Msg, int wParam, IntPtr lParam ); ?
??
? ? ? ? [DllImport( "Kernel32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern IntPtr CreateFileMapping( IntPtr hFile, IntPtr lpAttributes, uint flProtect, uint dwMaxSizeHi, uint dwMaxSizeLow, string lpName ); ?
??
? ? ? ? [DllImport( "Kernel32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern IntPtr OpenFileMapping( int dwDesiredAccess, [MarshalAs( UnmanagedType.Bool )] bool bInheritHandle, string lpName ); ?
??
? ? ? ? [DllImport( "Kernel32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern IntPtr MapViewOfFile( IntPtr hFileMapping, uint dwDesiredAccess, uint dwFileOffsetHigh, uint dwFileOffsetLow, uint dwNumberOfBytesToMap ); ?
??
? ? ? ? [DllImport( "Kernel32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern bool UnmapViewOfFile( IntPtr pvBaseAddress ); ?
??
? ? ? ? [DllImport( "Kernel32.dll", CharSet = CharSet.Auto )] ?
? ? ? ? public static extern bool CloseHandle( IntPtr handle ); ?
??
? ? ? ? [DllImport( "kernel32", EntryPoint = "GetLastError" )] ?
? ? ? ? public static extern int GetLastError(); ?
??
? ? ? ? [DllImport( "kernel32.dll" )] ?
? ? ? ? static extern void GetSystemInfo( out SYSTEM_INFO lpSystemInfo ); ?
??
? ? ? ? [StructLayout( LayoutKind.Sequential )] ?
? ? ? ? public struct SYSTEM_INFO ?
? ? ? ? { ?
? ? ? ? ? ? public ushort processorArchitecture; ?
? ? ? ? ? ? ushort reserved; ?
? ? ? ? ? ? public uint pageSize; ?
? ? ? ? ? ? public IntPtr minimumApplicationAddress; ?
? ? ? ? ? ? public IntPtr maximumApplicationAddress; ?
? ? ? ? ? ? public IntPtr activeProcessorMask; ?
? ? ? ? ? ? public uint numberOfProcessors; ?
? ? ? ? ? ? public uint processorType; ?
? ? ? ? ? ? public uint allocationGranularity; ?
? ? ? ? ? ? public ushort processorLevel; ?
? ? ? ? ? ? public ushort processorRevision; ?
? ? ? ? } ?
? ? ? ? /// <summary> ?
? ? ? ? /// 獲取系統的分配粒度 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? public static uint GetPartitionsize() ?
? ? ? ? { ?
? ? ? ? ? ? SYSTEM_INFO sysInfo; ?
? ? ? ? ? ? GetSystemInfo( out sysInfo ); ?
? ? ? ? ? ? return sysInfo.allocationGranularity; ?
? ? ? ? } ?
??
? ? ? ? const int ERROR_ALREADY_EXISTS = 183; ?
??
? ? ? ? const int FILE_MAP_COPY = 0x0001; ?
? ? ? ? const int FILE_MAP_WRITE = 0x0002; ?
? ? ? ? const int FILE_MAP_READ = 0x0004; ?
? ? ? ? const int FILE_MAP_ALL_ACCESS = 0x0002 | 0x0004; ?
??
? ? ? ? const int PAGE_READONLY = 0x02; ?
? ? ? ? const int PAGE_READWRITE = 0x04; ?
? ? ? ? const int PAGE_WRITECOPY = 0x08; ?
? ? ? ? const int PAGE_EXECUTE = 0x10; ?
? ? ? ? const int PAGE_EXECUTE_READ = 0x20; ?
? ? ? ? const int PAGE_EXECUTE_READWRITE = 0x40; ?
??
? ? ? ? const int SEC_COMMIT = 0x8000000; ?
? ? ? ? const int SEC_IMAGE = 0x1000000; ?
? ? ? ? const int SEC_NOCACHE = 0x10000000; ?
? ? ? ? const int SEC_RESERVE = 0x4000000; ?
??
? ? ? ? IntPtr m_fHandle; ?
??
? ? ? ? IntPtr m_hSharedMemoryFile = IntPtr.Zero; ?
? ? ? ? IntPtr m_pwData = IntPtr.Zero; ?
? ? ? ? bool m_bAlreadyExist = false; ?
? ? ? ? bool m_bInit = false; ?
? ? ? ? uint m_MemSize = 0x1400000;//20M ?
? ? ? ? long m_offsetBegin = 0; ?
? ? ? ? long m_FileSize = 0; ?
? ? ? ? FileReader File = new FileReader(); ?
? ??
? ? ? ? /// <summary> ?
? ? ? ? /// ?初始化文件 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="MemSize">緩沖大小</param> ?
? ? ? ? public ShareMemory( string filename, uint memSize ) ?
? ? ? ? { ?
? ? ? ? ? ? // 分頁映射文件時,每頁的起始位置startpos,必須為64K的整數倍。 ?
? ? ? ? ? ? // memSize即緩存區的大小必須是系統分配粒度的整倍說,window系統的分配粒度是64KB ?
? ? ? ? ? ? this.m_MemSize = memSize; ?
? ? ? ? ? ? Init( filename ); ?
? ? ? ? } ?
? ??
? ? ? ? /// <summary> ?
? ? ? ? /// 默認映射20M緩沖 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="filename"></param> ?
? ? ? ? public ShareMemory( string filename ) ?
? ? ? ? { ?
? ? ? ? ? ? this.m_MemSize = 0x1400000; ?
? ? ? ? ? ? Init( filename ); ?
? ? ? ? } ?
??
? ? ? ? ~ShareMemory() ?
? ? ? ? { ?
? ? ? ? ? ? Close(); ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 初始化共享內存 ?
? ? ? ? /// ??
? ? ? ? /// 共享內存名稱 ?
? ? ? ? /// 共享內存大小 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="strName"></param> ?
? ? ? ? protected void Init( string strName ) ?
? ? ? ? { ?
? ? ? ? ? ? //if (lngSize <= 0 || lngSize > 0x00800000) lngSize = 0x00800000; ?
??
? ? ? ? ? ? if ( !System.IO.File.Exists( strName ) ) throw new Exception( "未找到文件" ); ?
??
? ? ? ? ? ? System.IO.FileInfo f = new System.IO.FileInfo( strName ); ? ?
? ? ? ? ? ? m_FileSize = f.Length; ? ?
? ? ? ? ? ? m_fHandle = File.Open( strName ); ?
??
? ? ? ? ? ? if ( strName.Length > 0 ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? //創建文件映射 ?
? ? ? ? ? ? ? ? m_hSharedMemoryFile = CreateFileMapping( m_fHandle, IntPtr.Zero, ( uint )PAGE_READONLY, 0, ( uint )m_FileSize, "mdata" ); ?
? ? ? ? ? ? ? ? if ( m_hSharedMemoryFile == IntPtr.Zero ) ?
? ? ? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? ? ? m_bAlreadyExist = false; ?
? ? ? ? ? ? ? ? ? ? m_bInit = false; ?
? ? ? ? ? ? ? ? ? ? throw new Exception( "CreateFileMapping失敗LastError=" + GetLastError().ToString() ); ?
? ? ? ? ? ? ? ? } ?
? ? ? ? ? ? ? ? else ?
? ? ? ? ? ? ? ? ? ? m_bInit = true; ?
??
? ? ? ? ? ? ? ? 映射第一塊文件 ?
? ? ? ? ? ? ? ? //m_pwData = MapViewOfFile(m_hSharedMemoryFile, FILE_MAP_READ, 0, 0, (uint)m_MemSize); ?
? ? ? ? ? ? ? ? //if (m_pwData == IntPtr.Zero) ?
? ? ? ? ? ? ? ? //{ ?
? ? ? ? ? ? ? ? // ? ?m_bInit = false; ?
? ? ? ? ? ? ? ? // ? ?throw new Exception("m_hSharedMemoryFile失敗LastError=" + GetLastError().ToString()); ?
? ? ? ? ? ? ? ? //} ?
??
? ? ? ? ? ? } ?
? ? ? ? } ?
? ? ? ? /// <summary> ?
? ? ? ? /// 獲取高32位 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="intValue"></param> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? private static uint GetHighWord( UInt64 intValue ) ?
? ? ? ? { ?
? ? ? ? ? ? return Convert.ToUInt32( intValue >> 32 ); ?
? ? ? ? } ?
? ? ? ? /// <summary> ?
? ? ? ? /// 獲取低32位 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="intValue"></param> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? private static uint GetLowWord( UInt64 intValue ) ?
? ? ? ? { ?
??
? ? ? ? ? ? return Convert.ToUInt32( intValue & 0x00000000FFFFFFFF ); ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 獲取下一個文件塊 塊大小為20M ?
? ? ? ? /// </summary> ?
? ? ? ? /// <returns>false 表示已經是最后一塊文件</returns> ?
? ? ? ? public uint GetNextblock() ?
? ? ? ? { ?
? ? ? ? ? ? if ( !this.m_bInit ) throw new Exception( "文件未初始化。" ); ?
? ? ? ? ? ? //if ( m_offsetBegin + m_MemSize >= m_FileSize ) return false; ?
??
? ? ? ? ? ? uint m_Size = GetMemberSize(); ?
? ? ? ? ? ? if ( m_Size == 0 ) return m_Size; ?
??
? ? ? ? ? ? // 更改緩沖區大小 ?
? ? ? ? ? ? m_MemSize = m_Size; ?
??
? ? ? ? ? ? //卸載前一個文件 ?
? ? ? ? ? ? //bool l_result = UnmapViewOfFile( m_pwData ); ?
? ? ? ? ? ? //m_pwData = IntPtr.Zero; ?
??
??
? ? ? ? ? ? m_pwData = MapViewOfFile( m_hSharedMemoryFile, FILE_MAP_READ, GetHighWord( ( UInt64 )m_offsetBegin ), GetLowWord( ( UInt64 )m_offsetBegin ), m_Size ); ?
? ? ? ? ? ? if ( m_pwData == IntPtr.Zero ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? m_bInit = false; ?
? ? ? ? ? ? ? ? throw new Exception( "映射文件塊失敗" + GetLastError().ToString() ); ?
? ? ? ? ? ? } ?
? ? ? ? ? ? m_offsetBegin = m_offsetBegin + m_Size; ?
??
? ? ? ? ? ? return m_Size; //創建成功 ?
? ? ? ? } ?
? ? ? ? /// <summary> ?
? ? ? ? /// 返回映射區大小 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? private uint GetMemberSize() ?
? ? ? ? { ?
? ? ? ? ? ? if ( m_offsetBegin >= m_FileSize ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? return 0; ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else if ( m_offsetBegin + m_MemSize >= m_FileSize ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? long temp = m_FileSize - m_offsetBegin; ?
? ? ? ? ? ? ? ? return ( uint )temp; ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? ? ? return m_MemSize; ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 關閉內存映射 ?
? ? ? ? /// </summary> ?
? ? ? ? public void Close() ?
? ? ? ? { ?
? ? ? ? ? ? if ( m_bInit ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? UnmapViewOfFile( m_pwData ); ?
? ? ? ? ? ? ? ? CloseHandle( m_hSharedMemoryFile ); ?
? ? ? ? ? ? ? ? File.Close(); ?
? ? ? ? ? ? } ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 從當前塊中獲取數據 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="bytData">數據</param> ?
? ? ? ? /// <param name="lngAddr">起始數據</param> ?
? ? ? ? /// <param name="lngSize">數據長度,最大值=緩沖長度</param> ?
? ? ? ? /// <param name="Unmap">讀取完成是否卸載緩沖區</param> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? public void Read( ref byte[] bytData, int lngAddr, int lngSize, bool Unmap ) ?
? ? ? ? { ?
? ? ? ? ? ? if ( lngAddr + lngSize > m_MemSize ) ?
? ? ? ? ? ? ? ? throw new Exception( "Read操作超出數據區" ); ?
? ? ? ? ? ? if ( m_bInit ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? // string bb = Marshal.PtrToStringAuto(m_pwData);// ?
? ? ? ? ? ? ? ? Marshal.Copy( m_pwData, bytData, lngAddr, lngSize ); ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? throw new Exception( "文件未初始化" ); ?
? ? ? ? ? ? } ?
??
? ? ? ? ? ? if ( Unmap ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? bool l_result = UnmapViewOfFile( m_pwData ); ?
? ? ? ? ? ? ? ? if ( l_result ) ?
? ? ? ? ? ? ? ? ? ? m_pwData = IntPtr.Zero; ?
? ? ? ? ? ? } ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 從當前塊中獲取數據 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="bytData">數據</param> ?
? ? ? ? /// <param name="lngAddr">起始數據</param> ?
? ? ? ? /// <param name="lngSize">數據長度,最大值=緩沖長度</param> ?
? ? ? ? /// <exception cref="Exception: Read操作超出數據區"></exception> ?
? ? ? ? /// <exception cref="Exception: 文件未初始化"></exception> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? public void Read( ref byte[] bytData, int lngAddr, int lngSize ) ?
? ? ? ? { ?
? ? ? ? ? ? if ( lngAddr + lngSize > m_MemSize ) ?
? ? ? ? ? ? ? ? throw new Exception( "Read操作超出數據區" ); ?
? ? ? ? ? ? if ( m_bInit ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? Marshal.Copy( m_pwData, bytData, lngAddr, lngSize ); ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? throw new Exception( "文件未初始化" ); ?
? ? ? ? ? ? } ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 從當前塊中獲取數據 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="lngAddr">緩存區偏移量</param> ?
? ? ? ? /// <param name="byteData">數據數組</param> ?
? ? ? ? /// <param name="StartIndex">數據數組開始復制的下標</param> ?
? ? ? ? /// <param name="lngSize">數據長度,最大值=緩沖長度</param> ?
? ? ? ? /// <exception cref="Exception: 起始數據超過緩沖區長度"></exception> ?
? ? ? ? /// <exception cref="Exception: 文件未初始化"></exception> ?
? ? ? ? /// <returns>返回實際讀取值</returns> ?
? ? ? ? public uint ReadBytes( int lngAddr, ref byte[] byteData, int StartIndex, uint intSize ) ?
? ? ? ? { ?
? ? ? ? ? ? if ( lngAddr >= m_MemSize ) ?
? ? ? ? ? ? ? ? throw new Exception( "起始數據超過緩沖區長度" ); ?
??
? ? ? ? ? ? if ( lngAddr + intSize > m_MemSize ) ?
? ? ? ? ? ? ? ? intSize = m_MemSize - ( uint )lngAddr; ?
??
? ? ? ? ? ? if ( m_bInit ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? IntPtr s = new IntPtr( ( long )m_pwData + lngAddr ); // 地址偏移 ?
? ? ? ? ? ? ? ? Marshal.Copy( s, byteData, StartIndex, ( int )intSize ); ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? throw new Exception( "文件未初始化" ); ?
? ? ? ? ? ? } ?
??
? ? ? ? ? ? return intSize; ?
? ? ? ? } ?
??
? ? ? ? /// <summary> ?
? ? ? ? /// 寫數據 ?
? ? ? ? /// </summary> ?
? ? ? ? /// <param name="bytData">數據</param> ?
? ? ? ? /// <param name="lngAddr">起始地址</param> ?
? ? ? ? /// <param name="lngSize">個數</param> ?
? ? ? ? /// <returns></returns> ?
? ? ? ? private int Write( byte[] bytData, int lngAddr, int lngSize ) ?
? ? ? ? { ?
? ? ? ? ? ? if ( lngAddr + lngSize > m_MemSize ) return 2; //超出數據區 ?
? ? ? ? ? ? if ( m_bInit ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? Marshal.Copy( bytData, lngAddr, m_pwData, lngSize ); ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? return 1; //共享內存未初始化 ?
? ? ? ? ? ? } ?
? ? ? ? ? ? return 0; //寫成功 ?
? ? ? ? } ?
? ? } ?
? ? internal class FileReader ?
? ? { ?
? ? ? ? const uint GENERIC_READ = 0x80000000; ?
? ? ? ? const uint OPEN_EXISTING = 3; ?
? ? ? ? System.IntPtr handle; ?
??
? ? ? ? [DllImport( "kernel32", SetLastError = true )] ?
? ? ? ? public static extern System.IntPtr CreateFile( ?
? ? ? ? ? ? string FileName, ? ? ? ? ?// file name ?
? ? ? ? ? ? uint DesiredAccess, ? ? ? // access mode ?
? ? ? ? ? ? uint ShareMode, ? ? ? ? ? // share mode ?
? ? ? ? ? ? uint SecurityAttributes, ?// Security Attributes ?
? ? ? ? ? ? uint CreationDisposition, // how to create ?
? ? ? ? ? ? uint FlagsAndAttributes, ?// file attributes ?
? ? ? ? ? ? int hTemplateFile ? ? ? ? // handle to template file ?
? ? ? ? ); ?
??
? ? ? ? [System.Runtime.InteropServices.DllImport( "kernel32", SetLastError = true )] ?
? ? ? ? static extern bool CloseHandle ?
? ? ? ? ( ?
? ? ? ? ? ? System.IntPtr hObject // handle to object ?
? ? ? ? );?


? ? ? ? public IntPtr Open( string FileName ) ?
? ? ? ? { ?
? ? ? ? ? ? // open the existing file for reading ? ? ? ??
? ? ? ? ? ? handle = CreateFile ?
? ? ? ? ? ? ( ?
? ? ? ? ? ? ? ? FileName, ?
? ? ? ? ? ? ? ? GENERIC_READ, ?
? ? ? ? ? ? ? ? 0, ?
? ? ? ? ? ? ? ? 0, ?
? ? ? ? ? ? ? ? OPEN_EXISTING, ?
? ? ? ? ? ? ? ? 0, ?
? ? ? ? ? ? ? ? 0 ?
? ? ? ? ? ? ); ?
??
? ? ? ? ? ? if ( handle != System.IntPtr.Zero ) ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? return handle; ?
? ? ? ? ? ? } ?
? ? ? ? ? ? else ?
? ? ? ? ? ? { ?
? ? ? ? ? ? ? ? throw new Exception( "打開文件失敗" ); ?
? ? ? ? ? ? } ?
? ? ? ? } ?
??
? ? ? ? public bool Close() ?
? ? ? ? { ?
? ? ? ? ? ? return CloseHandle( handle ); ?
? ? ? ? } ?
? ? } ?
} ?
========

.NET Framework自帶的文件內存映射類

http://www.cnblogs.com/briny/archive/2012/11/25/2787188.html
最近一直為文件內存映射發愁,整個兩周一直折騰這個東西。在64位系統和32位系統還要針對內存的高低位進行計算。好麻煩。。還是沒搞定
偶然從MSDN上發現.NET 4.0把內存文件映射加到了.NET類庫中。。好像方便了很多啊。。比用C#直接調用WINDOWS API方便多了。所以
這個必須果斷記錄之。。。項目馬上要用,為了加強內存數據交換的效率。。這個。。。必須啊。。


任務


使用的方法或屬性


從磁盤上的文件中獲取表示持久內存映射文件的 MemoryMappedFile 對象。
MemoryMappedFile.CreateFromFile 方法。
獲取表示非持久內存映射文件(與磁盤上的文件不關聯)的 MemoryMappedFile 對象。
MemoryMappedFile.CreateNew 方法。
- 或 -
MemoryMappedFile.CreateOrOpen 方法。
獲取現有內存映射文件(持久文件或非持久文件)的 MemoryMappedFile 對象。
MemoryMappedFile.OpenExisting 方法。
獲取針對內存映射文件的順序訪問視圖的 UnmanagedMemoryStream 對象。
MemoryMappedFile.CreateViewStream 方法。
獲取針對內存映射文件的隨機訪問視圖的 UnmanagedMemoryAccessor 對象。
MemoryMappedFile.CreateViewAccessor 方法。
獲取要用于非托管代碼的 SafeMemoryMappedViewHandle 對象。
MemoryMappedFile.SafeMemoryMappedFileHandle 屬性。
- 或 -
MemoryMappedViewAccessor.SafeMemoryMappedViewHandle 屬性。
- 或 -
MemoryMappedViewStream.SafeMemoryMappedViewHandle 屬性。
將內存分配推遲到創建視圖后進行(僅限于非持久文件)。
(若要確定當前系統頁大小,請使用 Environment.SystemPageSize 屬性。)
帶 MemoryMappedFileOptions.DelayAllocatePages 值的 CreateNew 方法。
- 或 -
將 MemoryMappedFileOptions 枚舉作為參數的 CreateOrOpen 方法。
?
持久文件內存映射:


CreateFromFile 方法基于磁盤上的現有文件創建一個內存映射文件。


?1 using System;
?2 using System.IO;
?3 using System.IO.MemoryMappedFiles;
?4 using System.Runtime.InteropServices;
?5?
?6 class Program
?7 {
?8 ? ? static void Main(string[] args)
?9 ? ? {
10 ? ? ? ? long offset = 0x10000000; // 256 megabytes
11 ? ? ? ? long length = 0x20000000; // 512 megabytes
12?
13 ? ? ? ? // Create the memory-mapped file.
14 ? ? ? ? using (var mmf = MemoryMappedFile.CreateFromFile(@"c:\ExtremelyLargeImage.data", FileMode.Open,"ImgA"))
15 ? ? ? ? {
16 ? ? ? ? ? ? // Create a random access view, from the 256th megabyte (the offset)
17 ? ? ? ? ? ? // to the 768th megabyte (the offset plus length).
18 ? ? ? ? ? ? using (var accessor = mmf.CreateViewAccessor(offset, length))
19 ? ? ? ? ? ? {
20 ? ? ? ? ? ? ? ? int colorSize = Marshal.SizeOf(typeof(MyColor));
21 ? ? ? ? ? ? ? ? MyColor color;
22?
23 ? ? ? ? ? ? ? ? // Make changes to the view.
24 ? ? ? ? ? ? ? ? for (long i = 0; i < length; i += colorSize)
25 ? ? ? ? ? ? ? ? {
26 ? ? ? ? ? ? ? ? ? ? accessor.Read(i, out color);
27 ? ? ? ? ? ? ? ? ? ? color.Brighten(10);
28 ? ? ? ? ? ? ? ? ? ? accessor.Write(i, ref color);
29 ? ? ? ? ? ? ? ? }
30 ? ? ? ? ? ? }
31 ? ? ? ? }
32 ? ? }
33 }
34?
35 public struct MyColor
36 {
37 ? ? public short Red;
38 ? ? public short Green;
39 ? ? public short Blue;
40 ? ? public short Alpha;
41?
42 ? ? // Make the view brigher.
43 ? ? public void Brighten(short value)
44 ? ? {
45 ? ? ? ? Red = (short)Math.Min(short.MaxValue, (int)Red + value);
46 ? ? ? ? Green = (short)Math.Min(short.MaxValue, (int)Green + value);
47 ? ? ? ? Blue = (short)Math.Min(short.MaxValue, (int)Blue + value);
48 ? ? ? ? Alpha = (short)Math.Min(short.MaxValue, (int)Alpha + value);
49 ? ? }
50 }


?非持久文件內存映射:


CreateNew 和 CreateOrOpen 方法創建一個未映射到磁盤上的現有文件的內存映射文件。


?1 using System;
?2 using System.IO;
?3 using System.IO.MemoryMappedFiles;
?4 using System.Threading;
?5?
?6 class Program
?7 {
?8 ? ? // Process A:
?9 ? ? static void Main(string[] args)
10 ? ? {
11 ? ? ? ? using (MemoryMappedFile mmf = MemoryMappedFile.CreateNew("testmap", 10000))
12 ? ? ? ? {
13 ? ? ? ? ? ? bool mutexCreated;
14 ? ? ? ? ? ? Mutex mutex = new Mutex(true, "testmapmutex", out mutexCreated);
15 ? ? ? ? ? ? using (MemoryMappedViewStream stream = mmf.CreateViewStream())
16 ? ? ? ? ? ? {
17 ? ? ? ? ? ? ? ? BinaryWriter writer = new BinaryWriter(stream);
18 ? ? ? ? ? ? ? ? writer.Write(1);
19 ? ? ? ? ? ? }
20 ? ? ? ? ? ? mutex.ReleaseMutex();
21?
22 ? ? ? ? ? ? Console.WriteLine("Start Process B and press ENTER to continue.");
23 ? ? ? ? ? ? Console.ReadLine();
24?
25 ? ? ? ? ? ? Console.WriteLine("Start Process C and press ENTER to continue.");
26 ? ? ? ? ? ? Console.ReadLine();
27?
28 ? ? ? ? ? ? mutex.WaitOne();
29 ? ? ? ? ? ? using (MemoryMappedViewStream stream = mmf.CreateViewStream())
30 ? ? ? ? ? ? {
31 ? ? ? ? ? ? ? ? BinaryReader reader = new BinaryReader(stream);
32 ? ? ? ? ? ? ? ? Console.WriteLine("Process A says: {0}", reader.ReadBoolean());
33 ? ? ? ? ? ? ? ? Console.WriteLine("Process B says: {0}", reader.ReadBoolean());
34 ? ? ? ? ? ? ? ? Console.WriteLine("Process C says: {0}", reader.ReadBoolean());
35 ? ? ? ? ? ? }
36 ? ? ? ? ? ? mutex.ReleaseMutex();
37 ? ? ? ? }
38 ? ? }
39 }
========

總結

以上是生活随笔為你收集整理的C#内存映射文件学习总结的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产a级片免费观看 | 五月网婷婷 | 精品久久美女 | 激情综合网天天干 | 国产第一页福利影院 | 激情图片区 | 偷拍区另类综合在线 | www.黄色| 在线看av网址 | 国产精品一区免费看8c0m | 亚洲成人精品在线观看 | 欧美国产日韩激情 | 日韩,中文字幕 | 最近中文字幕完整视频高清1 | 国产无遮挡又黄又爽在线观看 | 一区二区三区在线观看免费 | 日韩在线三级 | 久久久国产在线视频 | wwxxxx日本| 91精品国产综合久久福利 | 一区二区三区国产欧美 | 亚洲 欧美 国产 va在线影院 | 国产精品视频app | 日p在线观看 | 久久理伦片 | 精品久久久久久久久久 | 色国产在线| 一区在线观看 | 又爽又黄又刺激的视频 | 日产av在线播放 | 成年人免费观看国产 | 久久曰视频 | 色综合久久88| 欧美色图另类 | 天天综合天天综合 | 亚洲中字幕 | 99国产在线观看 | 国产九九热视频 | 久久综合九色综合97婷婷女人 | 日韩综合一区二区三区 | 久久久久一区 | 91精品啪在线观看国产线免费 | 国产精品观看视频 | 午夜精品久久久久久久爽 | 日韩久久片 | 人九九精品 | 中文字幕日韩在线播放 | 欧美日韩一区二区三区在线免费观看 | 国产97视频 | 黄色大全视频 | 天天插天天干天天操 | 欧美日韩激情视频8区 | 精品国产欧美一区二区三区不卡 | 三级在线视频播放 | 黄a在线 | 久草免费在线观看 | 欧美二区三区91 | 最近免费观看的电影完整版 | 天天躁天天狠天天透 | 国产精在线 | 在线免费视频一区 | 久久免费毛片视频 | 日韩久久午夜一级啪啪 | bbbb操bbbb | 欧美日韩视频 | 国内精品久久久久影院男同志 | 精品国产综合区久久久久久 | av在线永久免费观看 | 日韩久久网站 | 婷婷色5月 | 青青色影院 | 亚洲精品乱码久久久久久久久久 | 日韩中文字幕免费在线观看 | 亚洲精品高清视频在线观看 | 成片视频在线观看 | 国产精品亚洲片夜色在线 | www.天天干 | 午夜久久精品 | 成年人免费电影在线观看 | 精品久久久精品 | 亚洲综合在线发布 | 狠狠操综合 | 国产999视频在线观看 | 欧美精品一区二区三区四区在线 | 999久久国精品免费观看网站 | 色99导航 | www天天干| 日韩亚洲欧美中文字幕 | 日韩高清精品一区二区 | www久久久久| 色综合久久中文综合久久牛 | 毛片视频网址 | 91香蕉视频 mp4 | 国产高清精品在线 | 国外av在线 | 国产精品18久久久久久久久久久久 | 91专区在线观看 | 精品亚洲欧美无人区乱码 | 激情综合久久 | 国产一级做a爱片久久毛片a | 婷婷丁香狠狠爱 | 久久免费视频一区 | 亚洲黄色在线观看 | 操操操人人 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 91福利视频一区 | 青草视频网| 亚洲综合在 | 日韩一区二区三区免费视频 | 国产高清在线看 | 91麻豆产精品久久久久久 | 精品久久视频 | 国内精品中文字幕 | www.香蕉视频 | 欧日韩在线视频 | 91久久国产露脸精品国产闺蜜 | 日本中文字幕在线一区 | 色丁香久久 | 国产色中涩 | 国产精品人成电影在线观看 | 免费观看成年人视频 | 成人作爱视频 | 中文字幕制服丝袜av久久 | 一区精品在线 | 久久久精品网站 | 天天狠狠| 国产精品成人免费精品自在线观看 | 亚洲国产高清在线观看视频 | 国产一区二区网址 | 丁香六月色 | 日韩二区三区在线 | 免费网站看av片 | 中文字幕免费国产精品 | 国产精品青草综合久久久久99 | 日韩欧美精品在线 | 丝袜足交在线 | 国产精品第一页在线 | 四虎在线影视 | 欧美日韩亚洲在线 | 成人a v视频 | 国产成在线观看免费视频 | 日日爽天天 | .国产精品成人自产拍在线观看6 | 黄色成品视频 | 人人爽人人爽人人爽学生一级 | 欧美另类美少妇69xxxx | 婷婷天天色 | 中文一区在线观看 | 成人欧美一区二区三区在线观看 | 天天摸天天舔天天操 | 亚洲精品麻豆 | 日韩视频在线观看视频 | 夜夜狠狠 | 丁香六月久久综合狠狠色 | 国产黄色美女 | 在线观看国产亚洲 | 成人在线视频一区 | 亚洲专区视频在线观看 | 男女视频久久久 | 久久久91精品国产一区二区三区 | 91重口视频| 96精品在线| 视频国产区 | 韩国av免费在线观看 | 国产精品国产三级在线专区 | adn—256中文在线观看 | 国产91精品一区二区麻豆亚洲 | 欧美在线观看小视频 | 亚洲精品国产精品99久久 | 国产成人精品一区二区三区福利 | 性色va | 国产精品在线看 | 色网免费观看 | 国产在线观看免费av | 日韩中文字幕一区 | 美女网站在线免费观看 | 国产日韩欧美在线影视 | 天天操狠狠干 | 91色吧 | 最近最新中文字幕视频 | 国产一区二区视频在线 | 在线免费看黄网站 | 久久国产精品99精国产 | 国产视频美女 | 麻豆一区二区三区视频 | 国产自制av| 99视频精品视频高清免费 | 国产一区在线观看免费 | 人人看人人爱 | 日韩av电影中文字幕在线观看 | 天天操天天射天天 | 日韩精品无 | 99精品黄色| 一区二区三区在线观看免费视频 | 日韩黄在线观看 | 婷婷丁香花五月天 | 亚洲精品乱码久久久久久蜜桃91 | 日韩精品免费一区二区在线观看 | 亚洲aⅴ在线 | 黄色毛片在线 | 91热爆在线观看 | 久草电影在线观看 | 在线日本看片免费人成视久网 | 国产伦理一区二区 | 欧美色操 | 日韩一区正在播放 | 91九色国产视频 | 午夜影视一区 | 成年人免费在线观看网站 | av九九九 | 黄色av成人在线 | 伊人色综合久久天天网 | 日日摸日日添日日躁av | 美女久久久久久久久久久 | 国产91国语对白在线 | 一区二区精 | 国产一区在线观看视频 | 欧美精品一区二区在线播放 | 免费视频一区二区 | 成人欧美日韩国产 | 国产色女 | 97超碰国产精品女人人人爽 | 麻豆视频免费入口 | 免费成人av在线 | 在线观看午夜 | 人人看看人人 | 久久视频在线免费观看 | 色天天综合久久久久综合片 | 在线亚洲成人 | 三上悠亚在线免费 | 久久官网| 国产精品美女久久久久久2018 | 色噜噜狠狠狠狠色综合久不 | 91精品在线免费观看视频 | 久草www | 国产精品手机在线 | 国产成人精品午夜在线播放 | 国产成人亚洲在线观看 | 综合网伊人 | 中文字幕在线观看免费 | 91视频国产高清 | 国产无遮挡又黄又爽在线观看 | 国产在线最新 | 久久国产精品免费视频 | av官网 | 久久精品视频在线观看免费 | 天天干天天做 | 亚洲在线网址 | 久久久国际精品 | 亚洲国产三级在线观看 | 国产99中文字幕 | 日韩最新在线视频 | 欧美日韩一区二区久久 | 亚洲永久字幕 | 欧美日本中文字幕 | 精品久久国产 | 欧美性护士 | 久久成人黄色 | av在线一二三区 | 久久69av | 美女国内精品自产拍在线播放 | 香蕉视频4aa | 午夜精品一区二区三区在线观看 | 午夜在线观看一区 | 亚洲精品99久久久久中文字幕 | 91精品在线播放 | 97久久久免费福利网址 | 欧美精品免费在线 | 国产福利91精品一区二区三区 | 99精品在线 | 国产精品美女久久久免费 | 国产一级在线免费观看 | 九九免费精品视频在线观看 | 黄色av电影在线 | 97成人精品视频在线观看 | 久久精品久久久久 | 日韩在线视频不卡 | 深爱婷婷| 亚洲在线看| 久久久久久蜜桃一区二区 | 欧美一级小视频 | 日韩黄色在线电影 | 久久久久欧美精品 | 国产精品久久三 | 成人作爱视频 | 超碰在线资源 | 在线观看成人一级片 | 叶爱av在线 | 国产97在线观看 | 成人在线视频一区 | 色婷婷激情 | 九九久久电影 | 波多野结依在线观看 | 久久免费中文视频 | 婷婷丁香激情 | 日日夜精品 | 制服丝袜欧美 | 99爱视频 | 国产一区精品在线 | 天天夜操 | 在线观看日韩中文字幕 | 久久久免费视频播放 | 人人插人人艹 | 六月丁香综合网 | 99精品视频在线播放免费 | 久久久精品国产一区二区电影四季 | 四虎影视成人永久免费观看视频 | 天天色天天色天天色 | 欧美与欧洲交xxxx免费观看 | 又爽又黄又刺激的视频 | 天天操夜夜看 | 成人福利在线 | 久久精品一二三区 | 成人av免费在线播放 | 久久视了| 国产区久久 | 精品久久国产精品 | 久久久999精品视频 国产美女免费观看 | 免费亚洲成人 | 欧美精品在线观看一区 | 亚洲成人中文在线 | 午夜精品福利一区二区三区蜜桃 | 成在人线av | 精品视频在线观看 | 96精品视频 | www.五月激情.com | 成年人在线免费看片 | 亚洲欧美视频网站 | 欧美一级电影在线观看 | 黄网站免费久久 | 国产精品久久一区二区无卡 | 国产高清在线免费 | 免费在线观看一区二区三区 | 欧美性色19p | 天天干天天插 | 四虎成人精品永久免费av | 国产精品久久久久久久久费观看 | 亚洲va欧美va人人爽 | 奇米影视777四色米奇影院 | 亚洲国产激情 | 97国产在线播放 | 国产伦精品一区二区三区免费 | 婷婷丁香色 | 99精品视频精品精品视频 | 青青草国产在线 | 激情欧美国产 | 青青草国产精品 | 久久成人精品 | 九九热只有这里有精品 | 婷婷国产在线 | 亚洲综合在线五月天 | 国产一区二区精 | 少妇bbb| 国产精品av一区二区 | 天天操天天干天天爽 | 欧美天天干 | 日韩激情片在线观看 | 7777精品伊人久久久大香线蕉 | 久久国产精品视频 | av网在线观看 | 久久久久久久久久福利 | a级片久久| 亚洲丝袜一区二区 | 国产亚洲免费的视频看 | 亚洲精品久久久久中文字幕二区 | 91成人观看 | 久久草在线免费 | 色av男人的天堂免费在线 | 少妇搡bbbb搡bbb搡aa | 91麻豆免费视频 | 日韩欧美精品在线视频 | 久久av影院 | 午夜成人免费电影 | 久久国产高清视频 | 日本视频久久久 | 狠狠色狠狠色终合网 | 深爱激情婷婷网 | 亚洲 欧洲av | 午夜精品一二三区 | 三级av网站 | 九九热在线播放 | 亚洲第一区在线观看 | 中文字幕高清免费日韩视频在线 | 免费在线h | 在线观看免费中文字幕 | 日韩精品一区二区三区不卡 | 少妇自拍av| 国产色婷婷精品综合在线手机播放 | 亚洲欧美日韩精品久久久 | 九九亚洲精品 | 国产vs久久 | 久人人| 国产精品第一页在线观看 | 97香蕉久久国产在线观看 | 中文字幕久久精品 | 亚洲国产最新 | 青青草国产在线 | 天天干天天综合 | 久久久久国产精品一区 | 国产精品久久久视频 | a一片一级 | 国产日韩精品一区二区三区在线 | 福利视频一二区 | 国产一级片免费播放 | aaaaaa毛片 | 日韩av女优视频 | 日韩成人黄色 | 中文字幕久久精品 | 久久午夜国产精品 | 国产中出在线观看 | 日韩中文在线电影 | 国产在线久草 | 国产精品免费视频久久久 | 亚洲一区免费在线 | 99c视频在线| 欧美成人在线免费 | 观看免费av| 久久精品一区二区三区视频 | 国产一区欧美在线 | 色综合久久中文字幕综合网 | 欧美激情另类文学 | 日本夜夜草视频网站 | 亚洲精品一区二区久 | 久久精品福利 | 美女免费黄视频网站 | 国产亚洲精品久 | www免费| 超碰97成人| 在线你懂的视频 | 精品在线二区 | 国产美女免费观看 | 国产99久久久精品视频 | 成人性生交视频 | 日韩字幕在线观看 | 中文字幕在线中文 | 久久亚洲欧美日韩精品专区 | 色综合狠狠干 | 久色伊人| 最近2019年日本中文免费字幕 | 国产精品不卡在线播放 | 97视频在线免费播放 | 精品视频成人 | 国产91精品看黄网站在线观看动漫 | 一级性视频 | 日韩成人在线一区二区 | 国产精品久久久久久久久免费 | 亚洲欧美精品一区二区 | 日韩剧情 | 粉嫩一二三区 | 国产精品9999久久久久仙踪林 | 免费高清在线观看成人 | 免费在线观看一区二区三区 | 久久久久久久久久久久久9999 | 欧美亚洲精品一区 | 日韩精品免费一区二区 | 日日摸日日添夜夜爽97 | 日本中文字幕一二区观 | 日本三级不卡 | 人人爱人人舔 | 黄色小说网站在线 | 狠狠久久综合 | 最近更新好看的中文字幕 | 亚洲五月婷婷 | 亚洲精品a区 | 色婷婷婷| 肉色欧美久久久久久久免费看 | 91自拍视频在线观看 | 成人91av| 高清国产一区 | 福利精品在线 | 成年人网站免费观看 | 在线а√天堂中文官网 | aaa亚洲精品一二三区 | www.超碰 | 亚色视频在线观看 | 精品国产一区二区三区四区在线观看 | 精品久久一区 | 免费看黄色小说的网站 | www.福利视频| 成人av片在线观看 | 91在线网址 | 西西444www | 日本激情中文字幕 | 精品一区二区三区四区在线 | 欧美高清视频不卡网 | a在线免费| 在线免费黄色片 | 99久久久久| 在线午夜 | 日韩欧美一区二区不卡 | 麻豆系列在线观看 | 在线成人观看 | 夜夜操网站 | 久久久久久免费网 | 成人h在线 | 2019精品手机国产品在线 | 播五月综合 | 亚洲 成人 一区 | 手机看片国产日韩 | 精品91久久久久 | 最近高清中文字幕 | 国产热re99久久6国产精品 | 国产一区电影在线观看 | 91精品国产99久久久久 | 成人毛片久久 | 麻花传媒mv免费观看 | 中文字幕文字幕一区二区 | 久久成人国产精品免费软件 | 成人黄色大片在线观看 | 精选久久 | 超碰人人在线观看 | 婷婷丁香九月 | www.亚洲精品在线 | 天天操天天干天天爱 | 西西www4444大胆视频 | japanesefreesexvideo高潮 | 免费看污的网站 | 欧美一区,二区 | 欧美激情另类文学 | 亚洲国内精品 | 午夜影视一区 | 精品无人国产偷自产在线 | 国产精品麻豆视频 | 久久久久亚洲天堂 | 国产精品精品国产色婷婷 | 久久一精品 | 国产中出在线观看 | 国产欧美日韩精品一区二区免费 | 99久久精品视频免费 | 五月天婷婷狠狠 | 亚洲午夜精 | 91看片黄色 | 色瓜 | 天堂av高清 | 国产精品人人做人人爽人人添 | 亚洲日本欧美在线 | 欧美a级免费视频 | 91麻豆精品国产91久久久久久 | 国产成人三级在线 | 又黄又爽的免费高潮视频 | 黄色三级久久 | av免费福利 | 一二三精品视频 | 国产97在线观看 | 中文字幕av最新更新 | 激情深爱 | 在线а√天堂中文官网 | 午夜日b视频 | 日批视频在线播放 | 久久超碰97| av中文字幕不卡 | 精品综合久久久 | 亚洲欧美日韩在线看 | 九九在线免费视频 | 国产精品精品久久久 | 99精品在线免费观看 | 久草爱| 五月天伊人 | 国产在线观看91 | 欧美淫视频 | 色91av| 在线中文字幕观看 | 午夜视频在线观看一区 | 日韩系列在线 | 日韩大片免费在线观看 | 亚洲成人精品在线 | 久久无码精品一区二区三区 | 婷久久| 中国一级片免费看 | 亚洲精品66 | 欧美精品免费在线 | 91麻豆精品 | 最新中文在线视频 | 婷婷久久一区二区三区 | 色偷偷人人澡久久超碰69 | 97成人在线免费视频 | 免费视频 你懂的 | 成人黄色资源 | 日韩91av | 成人a免费| 国产视频日韩视频欧美视频 | 国产在线色站 | 久久免费视频播放 | 国产成人在线观看 | 成人午夜剧场在线观看 | 久久五月婷婷丁香 | 最近中文字幕mv免费高清在线 | 午夜国产福利在线观看 | 欧美性护士 | 国产精品一区二区三区电影 | 成人久久 | 亚洲精品女人 | 久久小视频 | 久99久中文字幕在线 | 亚洲精品午夜视频 | 成人黄色在线电影 | 久久人人97超碰com | 日本中文乱码卡一卡二新区 | 精品国产一区二区三区蜜臀 | 亚洲国产精品久久 | 99精品国产视频 | 国产日韩欧美中文 | 日韩另类在线 | 在线观看亚洲电影 | 懂色av懂色av粉嫩av分享吧 | 日本在线精品视频 | 91九色免费视频 | 久久久精品国产免费观看同学 | www.亚洲精品在线 | 成人精品一区二区三区电影免费 | 在线日韩亚洲 | 久久综合久久久 | 免费三及片 | 国产色妞影院wwwxxx | 天天干天天做 | 91网免费观看| 天天在线免费视频 | 91九色在线视频 | 久久精品理论 | 日日噜噜噜噜夜夜爽亚洲精品 | 激情网色 | 精品国产色 | 手机av电影在线观看 | 日韩欧美综合视频 | 国产麻豆剧传媒免费观看 | 久久免费精品一区二区三区 | 日韩三级免费 | 色噜噜日韩精品欧美一区二区 | 91成人破解版 | 日韩在线欧美在线 | 午夜在线免费视频 | 成人av教育 | 欧美久久久影院 | 国产又黄又爽无遮挡 | 日韩av看片 | 婷婷六月天在线 | 亚洲成人资源在线观看 | av中文天堂 | 在线成人av | 国产不卡在线视频 | 中文字幕在线观看视频网站 | 精品国产一区二区三区久久久 | 91一区二区在线 | 国模视频一区二区三区 | 亚州国产视频 | 久久精品看片 | 国产色黄网站 | 精品96久久久久久中文字幕无 | 福利一区二区在线 | 黄色毛片视频免费 | 日本午夜在线亚洲.国产 | 韩国av永久免费 | 欧美网站黄色 | 黄色综合 | 免费成人av在线 | 国产理论在线 | 91久久精品日日躁夜夜躁国产 | 成人毛片一区二区三区 | 久久久久99精品国产片 | 久草视频在线资源站 | 五月婷视频 | 69绿帽绿奴3pvideos | 欧美韩国日本在线 | 中国黄色一级大片 | 在线看片视频 | 狠狠躁日日躁狂躁夜夜躁 | 久久深夜福利免费观看 | 日韩欧美一区二区三区在线观看 | 免费毛片一区二区三区久久久 | 国产玖玖在线 | 亚洲在线成人精品 | 亚洲婷婷网 | 操操操人人人 | 韩国精品视频在线观看 | 欧美性久久久 | 99久久精品久久久久久清纯 | 玖玖玖国产精品 | 九色琪琪久久综合网天天 | 久草在线视频首页 | 日韩av一区在线观看 | 成人亚洲免费 | 在线免费观看不卡av | 99久e精品热线免费 99国产精品久久久久久久久久 | 日韩欧美一区二区三区免费观看 | 亚洲第一中文字幕 | 免费网站在线观看人 | 国产精品一区在线观看 | 精品一区二区综合 | 日韩二区在线播放 | 日韩精品专区在线影院重磅 | 欧美精品在线观看免费 | 久热av在线| 色综合天天狠天天透天天伊人 | 欧美一级性 | 中文字幕精品一区二区三区电影 | 久草在线免费看视频 | 在线观看免费 | 有码中文在线 | 狠狠做深爱婷婷综合一区 | 午夜av免费| 天天干 天天摸 天天操 | 综合激情网 | 国产亚洲婷婷 | 国内精品毛片 | av无限看| 国产香蕉97碰碰碰视频在线观看 | 亚洲国产网址 | 开心激情久久 | 五月天激情视频在线观看 | 2018亚洲男人天堂 | 久久久999免费视频 日韩网站在线 | 久久国内免费视频 | av色综合 | 亚洲国产成人精品久久 | 亚洲欧美日韩国产一区二区 | 国产视频一区在线免费观看 | 色一级片 | 人人狠狠综合久久亚洲 | 在线观看黄色的网站 | 色资源网免费观看视频 | 国产精品一区二区吃奶在线观看 | 97精品免费视频 | 中文字幕免费 | 国产高清免费 | 91看片在线看片 | 欧美a性| 免费在线播放 | 国产综合精品一区二区三区 | 精品国产1区2区 | 在线观看一区 | 国产91精品一区二区麻豆网站 | av中文字幕亚洲 | 亚洲人xxx | 国产视频一区在线 | 久久国产精品久久w女人spa | 日韩一区二区在线免费观看 | 久久国产亚洲视频 | 啪啪精品 | 一区二精品| 亚洲专区视频在线观看 | 欧美a级在线免费观看 | 天天看天天干天天操 | 欧美三级免费 | 久久久久久美女 | 久久草在线视频国产 | 免费在线播放黄色 | 国产中文字幕网 | 麻豆视传媒官网免费观看 | 国产精品久久久久久久久费观看 | 一区二区三区污 | 免费精品视频在线观看 | 国产视频在线免费观看 | av午夜电影| 在线视频区 | 国语精品久久 | 天堂网一区 | 婷婷色在线 | 国内亚洲精品 | 伊人天天 | 亚洲手机av | 免费看污的网站 | 国产成人久久精品亚洲 | 国产精品久久久久久久99 | 成年人黄色在线观看 | 成人免费观看视频网站 | 视频一区二区在线观看 | 黄色精品久久久 | 密桃av在线| 免费日韩 精品中文字幕视频在线 | 欧美日本中文字幕 | 亚洲天堂精品视频在线观看 | 黄免费在线观看 | 免费av大全 | www.狠狠色| 亚洲激情 欧美激情 | 开心激情久久 | 日韩视频一区二区在线 | 国产一级性生活 | 欧美精品成人在线 | 国产精品成人一区二区 | 国产精品成人自产拍在线观看 | 久久久久免费精品 | 亚洲经典中文字幕 | 国产精品成人自产拍在线观看 | 92国产精品久久久久首页 | 国内精品美女在线观看 | 在线观看免费高清视频大全追剧 | 在线观看视频一区二区三区 | 日韩视频免费观看高清 | 天天曰天天 | 美女禁18| 欧美一区二区免费在线观看 | 97爱爱爱 | 亚洲视频免费在线看 | 欧美色888 | 久久91网| 激情偷乱人伦小说视频在线观看 | 日韩在线视频一区二区三区 | 成人污视频在线观看 | 国产淫片| 婷婷免费在线视频 | 免费久久网站 | 国产成人三级在线播放 | 日韩最新在线 | 日韩精品免费一区二区 | 超碰成人免费电影 | 亚洲精品福利视频 | 久久久久久久电影 | 亚洲视频精选 | 人人射人人澡 | 成人午夜电影在线 | 日日日天天天 | 国产精品av久久久久久无 | 日韩午夜高清 | 国产黄| 午夜丁香视频在线观看 | 日日爱av| 久章草在线 | 96亚洲精品久久久蜜桃 | 制服丝袜亚洲 | 免费人成网 | 精品视频www | 国产福利精品一区二区 | 亚洲天堂激情 | 人人超在线公开视频 | 在线免费观看黄色 | 国产精品九色 | 久久一区二区三区日韩 | av超碰在线 | 国产直播av | 视频一区二区三区视频 | 狠狠躁夜夜a产精品视频 | 黄a网站 | 久久亚洲综合国产精品99麻豆的功能介绍 | 免费看v片网站 | 日本精品中文字幕 | 国际精品久久久久 | av青草 | 久久精品视频在线播放 | 久久只精品99品免费久23小说 | 最新色视频| 麻豆传媒视频在线播放 | 精品美女久久久久久免费 | 中文字幕视频播放 | 这里有精品在线视频 | 在线之家官网 | 亚洲精品久久久久中文字幕m男 | 曰韩在线 | 久久精品一区二区三区国产主播 | 97超碰免费在线观看 | 欧美男女爱爱视频 | 91传媒91久久久 | 91麻豆精品国产自产在线游戏 | 91精品婷婷国产综合久久蝌蚪 | 欧美精品久久久久久 | 久久久久综合 | 一级黄色片在线免费观看 | 爱射综合 | 欧美一级片在线 | 国产最新在线视频 | 成人午夜在线电影 | 婷婷色中文网 | 91视频啪| 91九色在线视频 | 久久久久国产精品一区 | 人人插人人做 | 精品久久久久久久 | 欧美日韩一级视频 | 最近更新中文字幕 | 中文字幕在线观看视频网站 | 国产精品视频大全 | 欧美一区二区三区在线看 | 亚洲一区免费在线 | 久精品在线 | 93久久精品日日躁夜夜躁欧美 | 日本精品小视频 | 成人观看 | 狠狠久久综合 | 久久精品国产精品 | 999久久久免费视频 午夜国产在线观看 | 人人盈棋牌 | 亚洲视频观看 | 亚洲成人国产精品 | 91av视频在线播放 | 色资源网在线观看 | 久久手机免费观看 | 欧美色图另类 | 99精品视频99 | 波多野结衣一区二区 | 99久免费精品视频在线观看 | 国产黄色免费观看 | 韩日视频在线 | 亚洲国产经典视频 | 中文不卡视频在线 | 婷婷在线不卡 | 亚洲精品a区 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 操高跟美女 | 97超碰福利久久精品 | 日韩美精品视频 | 色a4yy| 国内精品视频在线 | 超碰日韩在线 | 免费能看的av| 激情视频区 | 黄色免费国产 | 97精品超碰一区二区三区 | 成人午夜电影在线观看 | 欧美日韩精品在线观看 | 日韩av高清 | 操久在线| 国产一区视频在线 | 亚洲黄在线观看 | 国产一区在线免费观看 | 成人黄色小说视频 | 国产.精品.日韩.另类.中文.在线.播放 | 成人网页在线免费观看 | 99久久久成人国产精品 | 成人黄色小说在线观看 | 国产在线一区二区三区播放 | 久草青青在线观看 | 狠狠操狠狠干2017 | 波多野结衣精品视频 | 久久成人国产精品 | 精品国产一区二区三区四区在线观看 | 国产一级免费在线观看 | 日韩一区二区免费视频 | 欧美少妇影院 | 五月天激情视频在线观看 | 日韩在线播放av | 一级片视频在线 | 国内外成人免费在线视频 | 免费黄色激情视频 | 欧美日一级片 | 午夜少妇一区二区三区 | 少妇资源站 | 色播五月激情五月 | 伊人宗合网| 久久精品久久99精品久久 | 香蕉影视在线观看 | 精品久久五月天 | 视频国产在线观看18 | 欧美日韩1区 | 国产精品mv| 伊人久久精品久久亚洲一区 | 99热国内精品 | 五月婷婷视频在线 | 97国产精品亚洲精品 | 在线观看理论 | 国产精品一区二区果冻传媒 | 99草视频 | 日韩精品一区二区三区免费观看视频 | 国产一区二区在线看 | 天天舔夜夜操 | 国产精品99免费看 | 99精品国产成人一区二区 | 国产不卡av在线播放 | 蜜桃视频色 | 国产又粗又猛又爽 | 国产精品综合av一区二区国产馆 | 国产成人一区二区三区 | 九九九九热精品免费视频点播观看 | 久久综合久久综合这里只有精品 | 探花视频在线版播放免费观看 | 亚洲日本在线视频观看 | 久久久久国产精品一区 | 精品电影一区二区 | 欧美久草视频 | 国产一卡久久电影永久 | 96av视频| 五月婷香蕉久色在线看 | 久久三级视频 | 91在线在线观看 | 九色激情网 | 91丨九色丨国产在线 | 日韩精品一区二区三区免费观看 | 91精品在线麻豆 | 99精品视频99 | 久草电影免费在线观看 | 国产精品ⅴa有声小说 | 综合激情婷婷 | 天天玩天天操天天射 | 五月天天色 | 粉嫩av一区二区三区四区在线观看 | 色婷婷骚婷婷 | 99超碰在线播放 | 特级西西人体444是什么意思 | 日韩高清不卡一区二区三区 | 欧美少妇18p | 国产精品视频线看 | 91人人澡| 国产伦精品一区二区三区高清 | 国产免费人成xvideos视频 | 一区二区三区四区五区在线 | 丁香久久激情 | 美女黄久久 | 中文在线 | 久久精品9 |