[英]Adding data to CArray gives error “cannot access private member declared in class 'CObject'”
[英]Error using CArray: cannot access private member declared in class CObject
我已經使用Microsoft Visual Studio 2010創建了一個dll,並且一切正常。 現在我想在導出的類中添加一個成員變量; 此成員變量是struct的向量,其中包含另一個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
};
}
給我錯誤的結構是“ 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
派生) 不可復制 。
因此,您final_block
結構中的CArray
數據成員也使后者無法復制。
因此,由於不可復制,因此不能在std::vector
中使用final_block
push_back()
實例。
一種選擇是在final_block
結構中final_block
** std::vector
替換CArray
。
或者,您可以為final_block
結構提供自定義副本構造函數和副本分配,並編寫用於復制CArray
成員的自定義代碼。
坦白說,我只是使用std::vector
而不是CArray
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.