我使用Microsoft Visual Studio 2010创建了一个dll,一切正常;现在我想将一个成员变量添加到我导出的类中;这个成员变量是struct的向量,它包含另一个结构的CArray。我在调试模式下遇到的错误是
error C2248: 'CObject::CObject': cannot access private member declared in class 'CObject' c:\program files (x86)\microsoft visual studio 10.0\vc\atlmfc\include\afxtempl.h 262
我知道我收到此错误,因为包含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
};
}
给我错误的结构是&#34; final_block&#34 ;;我用这种方式使用了这个结构:
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);
}
提前感谢您的帮助。
答案 0 :(得分:5)
问题是MFC CArray
(源自CObject
)无法复制。
因此,CArray
结构中的final_block
数据成员也会使后者不可复制。
因此,由于不可复制,您无法在push_back()
中final_block
std::vector
个CArray
个实例。
选项是在您的std::vector
结构中将** final_block
替换为final_block
。
或者,您可以为CArray
结构提供自定义复制构造函数和副本分配,并编写用于复制std::vector
成员的自定义代码。
坦率地说,我只使用CArray
代替{{1}}。