#include "stdafx.h"
#include <iostream>
#include <assert.h>
#include <cstring>
#include <atlstr.h>
#include <Windows.h>
#include <WinBase.h>
HANDLE hMap;
HANDLE hAddress;
int iErrCode;
//第一步要定義所要共享的內容的結構體
#pragma pack(1)
struct TShareMem
{
int i;
char Data[256];
float a[12];
TShareMem() {
i = 234;
int m=0, n=0;
while (m< 256) {
Data[m++] = 'b';
}
while (n < 12) {
a[n++] = n * 3.14f;
}
}
};
char *starShare;
char *szBuf;
TShareMem* pShareMem;
void CreateMap()
{
//char * strBuf;
//創建共享內存,這個函數的最后一個參數即是創建的共享內存的名稱
hMap = ::CreateFileMapping((HANDLE)-1, NULL, PAGE_READWRITE, 0, sizeof(TShareMem), _T("NewMap"));
if (hMap == NULL)
{
iErrCode = GetLastError();
std::cout << "不能創建內存映射文件!" << std::endl;
}
//寫共享內存區,將內存映射為文件
pShareMem = (TShareMem*)MapViewOfFile(hMap, FILE_MAP_WRITE, 0, 0, 0);
memcpy(pShareMem, starShare,sizeof(TShareMem));
}
void ReadMap(){
//打開剛剛創建的共享內存區
hMap = ::OpenFileMapping(FILE_MAP_WRITE, false, _T("NewMap"));
if (hMap == NULL)
{
iErrCode = GetLastError();
std::cout<<"不能定位內存映射文件塊!"<<std::endl;
}
//讀共享內存區
hAddress = MapViewOfFile(hMap, FILE_MAP_WRITE, 0, 0, 0);
//pShareMem = (TShareMem*)MapViewOfFile(hMap, FILE_MAP_WRITE, 0, 0, 0);
if (hAddress == NULL)
std::cout<<"Can''t View Memory Map"<<std::endl;
szBuf = new char[sizeof(TShareMem)];
//拷貝共享內存區的內容
CopyMemory(szBuf, hAddress, sizeof(TShareMem));
TShareMem *result = (TShareMem*)szBuf;
std::cout << result->a[6] << std::endl;
}
int main()
{
int i;
starShare = new char[sizeof(TShareMem)];
TShareMem shm ;
shm.Data[0] = 'q';
memcpy(starShare, &shm, sizeof(TShareMem));
while (1) {
std::cin >> i;
if (i == 1) {
CreateMap();
}
else {
ReadMap();
}
}
return 0;
}
c++寫內存
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
推薦閱讀更多精彩內容
- 本篇目的: c/c++中如何判斷大小端的函數 c/c++中通過指針法,移位法獲取多字節數據類型中的各個字節 jav...
- 在C++中,操作符 new 可以分配一片連續的內存空間。 例如: 課程錄像 北京大學郭煒/劉家瑛老師,C++程序設...