!!!急救如何使用同一内存区域

dot_net 2003-01-23 06:09:23
我有两个函数,一个套接字接受函数,将接收到的数据写入内存缓冲区。另外一个函数在读取并修改同样的内存缓冲,如何实现共享内存缓冲,而不产生冲突。我的代码简略如下:
void CClientSocket::OnReceive(int nErrorCode)
{
//......
//读套节子数据,写入缓冲
iRead = pClientSocket->Receive(g_lpBuf,0x8fff,0);
pMYView->TTYGetInfoReceived(this);
//......
}

void CMYView::TTYGetInfoReceived(CClientSocket *pClientSocket)
{
char lpBuf[0x1000];
//下面的代码将修改内存缓冲区g_lpBuf
//.........
}

我希望数据不断的由套节子读入,写到内存缓冲,又不断的被保存到文件中。
...全文
40 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
dot_net 2003-01-24
  • 打赏
  • 举报
回复
谢谢各位,明天或后天揭贴子
lipeng518888 2003-01-24
  • 打赏
  • 举报
回复
用临界区就可以了。
void InitializeCriticalSection(
LPCRITICAL_SECTION lpCriticalSection );
void EnterCriticalSection(
LPCRITICAL_SECTION lpCriticalSection );
void LeaveCriticalSection(
LPCRITICAL_SECTION lpCriticalSection );
void DeleteCriticalSection(
LPCRITICAL_SECTION lpCriticalSection );

MainThread
{
InitializeCriticalSection;
CreateThread;
.
.
.
EnterCriticalSection;
.
.
.
LeaveCriticalSection;
.
.
.
DeleteCriticalSection
}


ThreadProc
{
.
EnterCriticalSection;
.
.
.
LeaveCriticalSection;
.


}
dgxu 2003-01-24
  • 打赏
  • 举报
回复
方法比较多,可以用事件,CRITICAL_SECTION等
用CreateEvent()创建一个AutoReset的事件
ThreadReceiveProc()
{
WaitForSingleObject();
Receive();
SetEvent();
}

ThreadSave()
{
WaitForSingleObject();
SaveToFile();
SetEvent();
}
Anikan 2003-01-24
  • 打赏
  • 举报
回复
要简单的话就用个临界区吧
#include <afxmt.h>
class CClientSocket
{
...
//增加成员变量
CCriticalSection m_cs;
};
void CClientSocket::OnReceive(int nErrorCode)
{
//......
//读套节子数据,写入缓冲
m_cs.Lock();
iRead = pClientSocket->Receive(g_lpBuf,0x8fff,0);
m_cs.UnLock();
pMYView->TTYGetInfoReceived(this);
//......
}
void CMYView::TTYGetInfoReceived(CClientSocket *pClientSocket)
{
char lpBuf[0x1000];
m_cs.Lock();
//下面的代码将修改内存缓冲区g_lpBuf
//.........
m_cs.Unlock();
}

dot_net 2003-01-24
  • 打赏
  • 举报
回复
谁帮帮我
fireseed 2003-01-24
  • 打赏
  • 举报
回复
为何不使用我们标准而美丽的C++,却要去使用什么内存池呢?

定位的new——大家可能很少用到,看下面的例程



#include <iostream>
using namespace std;

class C
{
public:
int nVar;
};

char *pBuf = new char[1024];

void main()
{
C *po = new(pBuf)C; // 在pBuf内存中为po申请内存
po->nVar=6;
cout<<po->nVar;
// delete po; // 这句并不需要
delete []pBuf; // 在这句里统一释放内存
}



这就是你们想要的Memory pool ??
aben456 2003-01-23
  • 打赏
  • 举报
回复
GOOGLE搜索一下 多线程同步

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧