• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            共享內(nèi)存的實(shí)現(xiàn)

            先介紹個(gè)比較簡(jiǎn)單的程序,windows下讀內(nèi)存:

            #include 
            "stdafx.h"
            #include 
            <windows.h>
            #include 
            <iostream>
            using namespace std;

            const char FileMaping[255= "FileMaping";
            typedef 
            struct file_map_parameter_t
            {
                
            int i_id;
                
            int j_id;
                
            char c_id;
            }
            file_map_parameter_t;

            typedef file_map_parameter_t FileMap_t[
            100];
            file_map_parameter_t 
            * m_addr;

            bool ReadFileMapping()
            {
                size_t len 
            = sizeof(FileMaping);
                wchar_t
            * wstr_name = (wchar_t*)malloc((len+1)*sizeof(wchar_t));
                HANDLE m_handle 
            = ::OpenFileMapping(FILE_MAP_ALL_ACCESS,false,wstr_name);
                
            if (NULL == m_handle)
                
            {
                    m_handle 
            = ::CreateFileMapping((HANDLE)INVALID_HANDLE_VALUE,NULL,PAGE_READWRITE,0,
                        
            sizeof(FileMap_t),wstr_name);
                    
            if( NULL == m_handle)
                    
            {
                        cout
            <<"共享文件生成失敗!"<<endl;
                        
            return false;
                    }
             
                    
            else
                    
            {
                        cout
            <<"共享文件生成成功!"<<endl;
                    }


                }
             
                m_addr 
            = (file_map_parameter_t*)::MapViewOfFile(m_handle,FILE_MAP_WRITE,0,0,sizeof(FileMap_t));

                
            for (int i = 0;i<20;i++)
                
            {
                    file_map_parameter_t 
            * m_addrtmp;
                    m_addrtmp 
            = m_addr + i; 
                }

                
                
            return true;
            }

            int _tmain(int argc, _TCHAR* argv[])
            {
                ReadFileMapping();
                
            return 0;
            }


            寫共享內(nèi)存:
            #include "stdafx.h"
            #include <windows.h>
            #include <iostream>
            using namespace std;

            const char FileMaping[255] = "FileMaping";
            typedef struct file_map_parameter_t
            {
             int i_id;
             int j_id;
             char c_id;
            }file_map_parameter_t;

            typedef file_map_parameter_t FileMap_t[100];
            file_map_parameter_t * m_addr;

            bool WriteFileMapping()
            {
             size_t len = sizeof(FileMaping);
             wchar_t* wstr_name = (wchar_t*)malloc((len+1)*sizeof(wchar_t));
             HANDLE m_handle = ::OpenFileMapping(FILE_MAP_ALL_ACCESS,false,wstr_name);
             if (NULL == m_handle)
             {
              m_handle = ::CreateFileMapping((HANDLE)INVALID_HANDLE_VALUE,NULL,PAGE_READWRITE,0,
               sizeof(FileMap_t),wstr_name);
              if( NULL == m_handle)
              {
               cout<<"共享文件生成失敗!"<<endl;
               return false;
              }
              else
              {
               cout<<"共享文件生成成功!"<<endl;
              }

             }
             m_addr = (file_map_parameter_t*)::MapViewOfFile(m_handle,FILE_MAP_WRITE,0,0,sizeof(FileMap_t));

             for (int i = 0;i<20;i++)
             {
              (m_addr + i)->c_id = 'i';
              (m_addr + i)->i_id = i;
              (m_addr + i)->j_id = 2*i;
             }
             return true;
            }
            int _tmain(int argc, _TCHAR* argv[])
            {
             WriteFileMapping();
             return 0;
            }


            這里有一個(gè)問(wèn)題沒有解決:
                對(duì)共享內(nèi)存的大小問(wèn)題,比如說(shuō)上面寫的程序是已知共享內(nèi)存的大小,比如說(shuō)有20個(gè)struct,但是如果
            這個(gè)大小不是固定的比如類似于一個(gè)vector的話該怎么操作呢?

            利用boost::interprocess請(qǐng)看http://blog.csdn.net/great3779/article/details/7226388







            posted on 2012-11-19 10:45 sheng 閱讀(643) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            導(dǎo)航

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統(tǒng)計(jì)

            常用鏈接

            留言簿(1)

            隨筆檔案

            收藏夾

            同行

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            国产ww久久久久久久久久| 久久婷婷是五月综合色狠狠| 久久er99热精品一区二区| 97久久综合精品久久久综合| 夜夜亚洲天天久久| 久久人人添人人爽添人人片牛牛| 国产产无码乱码精品久久鸭| 久久国产综合精品五月天| 色诱久久久久综合网ywww| 久久国产美女免费观看精品| 久久久精品2019免费观看| 青青热久久国产久精品| 久久精品无码一区二区无码| 香蕉久久AⅤ一区二区三区| 99久久免费国产特黄| 久久精品视频一| 国产精品欧美久久久久天天影视| 久久综合狠狠综合久久| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久久久AV综合网成人| 欧美午夜A∨大片久久| 久久免费精品视频| 麻豆AV一区二区三区久久| 香蕉久久夜色精品国产2020| 国产免费久久精品99久久| av无码久久久久不卡免费网站| 欧美伊人久久大香线蕉综合| 久久激情亚洲精品无码?V| 久久青青草原精品影院| 国产精品久久永久免费| 无码精品久久久天天影视| 囯产极品美女高潮无套久久久| 精品久久久久久成人AV| 亚洲综合久久综合激情久久| 日本久久久精品中文字幕| 久久久免费精品re6| 97久久久精品综合88久久| 99久久精品免费看国产| 99久久国产主播综合精品| 国内精品久久久久久99| 久久亚洲国产成人影院|