• 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 进行同步发布的
  • 相关阅读:
    [HDU3487]Play with Chain
    [HDU3436]Queue-jumpers
    [HDU2475]Box
    [HDU1890]RoboticSort
    [BZOJ1500]维修数列
    [POJ3580]SuperMemo
    [POJ3481]Double Queue
    [BZOJ1269]文本编辑器editor
    简单的sql注入
    图片马的制作以及菜刀的使用
  • 原文地址:https://www.cnblogs.com/findumars/p/4683664.html
Copyright © 2020-2023  润新知