zoukankan      html  css  js  c++  java
  • CreateFileMapping和MapViewOfFile函数

    大家都是到PG是分布式网络事务处理数据库,与其他数据库优点之一就在于服务器与客户的交流是一对一的,所谓一对一是指,针对客户的每一连接服务器都会产生一个进程为其服务,那么问题就来了,这些进程间是如何交互、如何实现并发数据同步、保证数据正确性的问题呢?在PG中采用的就是共享内存+信号灯实现的,关于共享内存首先想到的就是CreateFileMapping和MapViewOfFile函数,下面是晚上搜索的一篇关于这两个函数的使用方法,原文如下:

    在开发软件过程里,也经常碰到进程间共享数据的需求。比如A进程创建计算数据,B进程进行显示数据的图形。这样的开发方式可以把一个大程序分开成独立的小程序,提高软件的成功率,也可以更加适合团队一起开发,加快软件的开发速度。下面就来使用文件映射的方式进行共享数据。先要使用函数CreateFileMapping来创建一个想共享的文件数据句柄,然后使用MapViewOfFile来获取共享的内存地址,然后使用OpenFileMapping函数在另一个进程里打开共享文件的名称,这样就可以实现不同的进程共享数据。

    函数CreateFileMapping、MapViewOfFile声明如下:

    WINBASEAPI
    __out
    HANDLE
    WINAPI
    CreateFileMappingA(
        __in     HANDLE hFile,
        __in_opt LPSECURITY_ATTRIBUTES lpFileMappingAttributes,
        __in     DWORD flProtect,
        __in     DWORD dwMaximumSizeHigh,
        __in     DWORD dwMaximumSizeLow,
        __in_opt LPCSTR lpName
        );
    WINBASEAPI
    __out
    HANDLE
    WINAPI
    CreateFileMappingW(
        __in     HANDLE hFile,
        __in_opt LPSECURITY_ATTRIBUTES lpFileMappingAttributes,
        __in     DWORD flProtect,
        __in     DWORD dwMaximumSizeHigh,
        __in     DWORD dwMaximumSizeLow,
        __in_opt LPCWSTR lpName
        );
    #ifdef UNICODE
    #define CreateFileMapping CreateFileMappingW
    #else
    #define CreateFileMapping CreateFileMappingA
    #endif // !UNICODE
     
    WINBASEAPI
    __out
    LPVOID
    WINAPI
    MapViewOfFile(
        __in HANDLE hFileMappingObject,
        __in DWORD dwDesiredAccess,
        __in DWORD dwFileOffsetHigh,
        __in DWORD dwFileOffsetLow,
        __in SIZE_T dwNumberOfBytesToMap
        );

    hFile是创建共享文件的句柄。

    lpFileMappingAttributes是文件共享的属性。

    flProtect是当文件映射时读写文件的属性。

    dwMaximumSizeHigh是文件共享的大小高位字节。

    dwMaximumSizeLow是文件共享的大小低位字节。

    lpName是共享文件对象名称。

    hFileMappingObject是共享文件对象。

    dwDesiredAccess是文件共享属性。

    dwFileOffsetHigh是文件共享区的偏移地址。

    dwFileOffsetLow是文件共享区的偏移地址。

    dwNumberOfBytesToMap是共享数据长度。

    调用函数的例子如下:

       //文件共享。
       void FileMapping(void)
       {
              //打开共享的文件对象。
              m_hMapFile = OpenFileMapping(FILE_MAP_ALL_ACCESS, FALSE,_T("TestFileMap"));
              if (m_hMapFile)
              {
                    //显示共享的文件数据。
                   LPTSTR lpMapAddr = (LPTSTR)MapViewOfFile(m_hMapFile,FILE_MAP_ALL_ACCESS,
                        0,0,0
    );
                    OutputDebugString(lpMapAddr);
              }
              else
              {
                    //创建共享文件。
                    m_hMapFile = CreateFileMapping( (HANDLE)0xFFFFFFFF,NULL,
                        PAGE_READWRITE,0,1024,_T("TestFileMap"
    ));
     
                    //拷贝数据到共享文件里。
                    LPTSTR lpMapAddr = (LPTSTR)MapViewOfFile(m_hMapFile,FILE_MAP_ALL_ACCESS,
                        0,0,0
    );
                    std::wstring strTest(_T("TestFileMap"));
                    wcscpy(lpMapAddr,strTest.c_str());                
      
                    FlushViewOfFile(lpMapAddr,strTest.length()+1);
              }
       }
    本文是使用 B3log Solo 从 SPARON 进行同步发布的
  • 相关阅读:
    UUID设主键让后续的开发工作更加方便
    S2SH整合FreeMarker
    轮询技术
    使DreamWeaver支持tml扩展名
    Editplus 的Record功能
    从注册表删除sqlserver注册
    ie8的新功能
    使用editplus 与 dreamweaver 协作开发
    安装SQL SERVER时提示"以前的某个程序安装已在安装计算机上创建挂起的文件操作 "解决方法
    选中文件夹设定为IIS站点主目录的批处理bat
  • 原文地址:https://www.cnblogs.com/findumars/p/4683664.html
Copyright © 2011-2022 走看看