我使用Microsoft Visual Studio 2010创建了一个dll,并且一切正常。现在我想在导出的类中添加一个成员变量;此成员变量是struct的 vector ,其中包含另一个struct的CArray。我在 Debug模式下出现的错误是



我知道我收到此错误,因为包含CArray的结构的构造函数存在问题,但我无法修复它。请帮我。
我在下面发布了代码。

导出舱:

namespace optFun
{
    // si posso definire altri casi in base a dove vengono collocati gli strumenti di gestione delle eccezioni
    enum RETURN{
        RETURN_INIT=0,
        RETURN_ERRORINREADING,
        RETURN_ERRORINPARALLEL,
        RETURN_ERRORINMAKESPAN,
        RETURN_SUCCESSFUL
    };

    struct DataPrescription{
    EDrug  NameDrug;
    float Dosage;
    EContainerType DestType;
    ELiquid IdDest;
    float CapacityDest;
    float Priority;
    bool ScaricoShaker;
    int  BlockNumber;

    DataPrescription(){
        NameDrug=EDrug_NoDrug;
        Dosage=0.0;
        DestType= EContainerType_Tot;
        IdDest=ELiquid_NoLiquid;
        CapacityDest=0.0;
        Priority=0.0;
        ScaricoShaker=true;
        BlockNumber=0;
    }

    DataPrescription(EDrug name,float dos,EContainerType dest,ELiquid ID,float cap_dest,float p,bool _ScaricoShaker,int _BlockNumber){
        NameDrug=name;
        Dosage=dos;
        DestType=dest;
        IdDest=ID;
        CapacityDest=cap_dest;
        Priority=p;
        ScaricoShaker=_ScaricoShaker;
        BlockNumber=_BlockNumber;
    }
};

struct final_block{

  CArray<DataPrescription> block_list;
  vector<load_info> carico;
  bool scarico_MI;
  final_block(){
      scarico_MI=false;
  }
};
    // This class is exported from the optFunDll.dll
    class OPTFUNDLL_API OptimizationTool
    {
    public:
        // funzione che implementa il modulo di ottimizzazione
        CArray<DataPrescription> OptList;
        time_info time;
        vector<final_block> execution_mode;
        vector<state_info> StatusInfo;
        vector<load_info> LoadIndication;
        CArray<DataPrescription> ShakingList; //lista dei soli farmaci da restituire nell'ordine ottimo di schedulazione

        OptimizationTool(void);
        ~OptimizationTool();

        void CreateDataPrescription(vector<block>&);
        //void CreateBlockPrescription(block&);
        RETURN scheduling(vector<string>,const char*,const char*,const char*);
        void InitializeParameter(double,int);
        void LoadDetails(vector<block>&,vector<magazzino_ospedale>&);
        //void ToLoad(ricetta&,vector<magazzino_ospedale>&,vector<magazzino_ospedale>&);
        void SyncronizeLoad(vector<block>&);

        // accessor function
        double get_PercVel();
        int get_CountSame();


    private:
        double _PercentMaximumVelocityOfSearchSpace; // % che determina range di variazione della velocità (e quindi anche della posizione)
        int _CountSame; // numero di stesse iterazioni dopo le quali la procedura di ottimizzazione si arresta


    };
}

给我错误的结构是“final_block”;我以这种方式使用此结构:
for(unsigned int i=0;i<output.size();i++){
           final_block pr;
           for(unsigned int j=0;j<output[i].list.size();j++){
               DataPrescription tmp(output[i].list[j].getID(),output[i].list[j].getdosage(),output[i].list[j].get_destination(),output[i].list[j].get_DestType(),output[i].list[j].get_CapacityDest(),output[i].list[j].getPriority(),output[i].list[j].processing_info.scarico_shaker,i+1);
               pr.block_list.Add(tmp);
           }
           pr.carico.push_back(this->LoadIndication[i]);
           pr.scarico_MI=output[i].scarico_MI;
          this->execution_mode.push_back(pr);
       }

在此先感谢您的帮助。

最佳答案

问题是MFC CArray(派生自CObject)是,不可复制

因此,CArray结构中的final_block数据成员也使后者无法复制。

因此,由于不可复制,因此不能在push_back()中使用final_blockstd::vector实例。

一种选择是在CArray结构中仅用** std::vector替换final_block

或者,您可以为final_block结构提供自定义副本构造函数和副本分配,并编写用于复制CArray成员的自定义代码。

坦白说,我只会使用std::vector而不是CArray

08-28 05:38