【发布时间】:2012-12-01 04:01:49
【问题描述】:
我有一个使用 fork() 的 C++ 程序,但我需要能够在父进程及其子进程之间共享一个可以读写的对象。从我的在线阅读来看,似乎 mmap 是这样做的方法。这是我所拥有的:
enum messageType {New = 0, Old = 1, No_Message = 2};
typedef struct {
enum messageType type;
unsigned int senderID;
char message[100];
} StoredMessageData;
struct StoredMessage {
unsigned int recipientID;
vector<StoredMessageData> messages;
StoredMessage(const unsigned int& intRecipient = 0, const vector<StoredMessageData>& data = vector<StoredMessageData>())
: recipientID(intRecipient), messages(data)
{
messages.reserve(10);
}
bool operator<(const StoredMessage& compareTo) const
{
return recipientID < compareTo.recipientID;
}
bool operator==(const StoredMessage& compareTo) const
{
return recipientID == compareTo.recipientID;
}
};
然后在main中:
set<StoredMessage> * msgs;
msgs = mmap(NULL, sizeof(set<StoredMessage>), PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANON, -1, 0);
然后在 main 中我使用 fork()。
我的问题分为两部分:
1) 一个集合的大小是可变的,我已经知道在每个分叉的进程中,我希望能够添加一个 StoredMessage 并将一个 StoredMessageData 添加到 StoredMessage 中的向量。但是,我不确定 mmap 可以处理这个......它不只是为基础对象分配足够的空间吗?我可以让它分配足够的空间让我进行这些添加吗?
2) main 中的上述代码当前正在抛出错误:
错误:从 âvoid*â 到 âstd::set, std::allocator 的无效转换 >*â
有谁知道这意味着什么/如何解决它?
提前谢谢你!
【问题讨论】:
-
我不想让人沮丧或任何事情,但如果你不能自己回答这些问题,你可能不应该这样做。实际上不,这行不通。
-
如果它们实际上是简单的问题,我深表歉意;我通常不使用 C++ 编程。但是,为了学习,提出有用的答案而不是贬低的答案可能在未来更有帮助。
-
我的意思是你甚至没有意识到这种方法的实际问题是什么。而且您显然没有掌握 C++ 基础知识。答案又是“这行不通”。
-
我的意思是你上面的回答是错误的......他们让我不知道为什么这不起作用,我可能能够建设性地使用它来实际学习任何东西,也他们是否提供了我可能会研究的任何可能会更好的东西。正如我所说,我不是 C++ 程序员,也没有声称对 C++ 有任何深入的了解,显然,从我的问题的明显愚蠢来看,我没有。但是,我并没有从你那刻薄的 cmets 那里学到任何东西,也没有在使用 C++ 方面做得更好。
-
@GossamerShadow,请记住
std::set不仅仅是std::set对象本身;std::set在幕后为其树节点等分配了许多其他内存位。您必须使用placement new 和自定义std::allocator来确保集合及其所有内部数据结构适合预分配共享内存段,以及处理同步。为什么不使用文件系统(set=directory, key=filename)?还是让父母管理集合,孩子通过管道向父母发送集合读/写命令?
标签: c++ multithreading set fork mmap