Boost ::用于C ++数据复制的信号

最近我有一个看起来像的课程
class IGraphElement{
    typedef void FuncCharPtr(char*, int) ;
public:
    void Add(FuncCharPtr* f)
    {
        FuncVec.push_back(f);
    }
    void CastData(char * data, int length){
        for(size_t i = 0 ; i < FuncVec.size(); i++){
            char* dataCopy = new char[length];
            memcpy(dataCopy, data, length);
            FuncVec[i](dataCopy, length);
        }
    }
private:
    vector<FuncCharPtr*> FuncVec ;
};
在那里,我向所有订阅者提供了指向数据副本的指针。现在我想让我的班级使用boost。我明白,通过提升,我将从typedef和vector中获得免费而不是我会有类似的东西
class IGraphElement{

public:
  signal<void (char*, int) > SigB;
但是如何为我重写CastData以保持对将被发送/转发给订阅者的数据的控制?     
已邀请:
你犯了一个错误:你假设你正在调用的函数将释放你给它的资源(char *指针)。你应该做的事情如下:
void CastData(char * data, int length){
    for(size_t i = 0 ; i < FuncVec.size(); i++){
        char* dataCopy = new char[length];
        memcpy(dataCopy, data, length);
        FuncVec[i](dataCopy, length);
        delete[] dataCopy;
    }
}
现在,关于boost :: signals。信号只包含一个函数指针列表。如果信号被引发,它只是用指定的参数调用该列表中的每个函数。就像是:
class signal { //non-templated version
public:
    void operator() (Params) 
    {
        for (FuncList::iterator i = f_.begin(); i != f_.end(); ++i) {
            (**i)(Params);
        }
    }
private:
    typedef ... Function;
    typedef std::vector<Function> FuncList;
    FuncList f_;
}
由于参数是直接传递的,因此您必须将数据结构封装到辅助类中。您将在复制构造函数中执行内存管理。     

要回复问题请先登录注册