我使用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_block
的std::vector
实例。
一种选择是在CArray
结构中仅用** std::vector
替换final_block
。
或者,您可以为final_block
结构提供自定义副本构造函数和副本分配,并编写用于复制CArray
成员的自定义代码。
坦白说,我只会使用std::vector
而不是CArray
。