我將子對象解析爲方法,但我的子數據丟失。請告訴如何在不丟失數據的情況下解析對象。如何在方法中傳遞子對象
class A
{
int size;
std::string name;
public:
A(const std::string &name, int &size){}
virtual B *C();
}
function D()
{
int size = 10;
std::string name = "name";
return new A(name , size);
}
B *A::C(){
\\here I need name and size
}
寫信跟大小給它的值是0,而不是10和名字給它分段故障
感謝4的幫助下提前
更新1 我的代碼抽象
class PrototypeAST
{
int size;
std::string FnName;
std::vector<std::string> ArgNames;
public:
PrototypeAST(const std::string &fnName, const std::vector<std::string> &argNames, int &size)
: FnName(fnName), ArgNames(argNames) {}
Function *Codegen();
void CreateArgumentAllocas(Function *F);
};
static PrototypeAST *ParsePrototype() {
int size;
std::string FnName = IdentifierStr;
getNextToken();//eat id1
std::vector<std::string> ArgNames;
if(CurTok != ')')
{
getNextToken(); //eat int
ArgNames.push_back(IdentifierStr);
getNextToken();// eat id
while (CurTok == ',')
{
getNextToken(); //eat ,
getNextToken(); //eat int
ArgNames.push_back(IdentifierStr);
getNextToken();// eat id
}
}
// success.
getNextToken(); // eat ')'.
size = ArgNames.size();
return new PrototypeAST(FnName, ArgNames, size);
}
Function *PrototypeAST::Codegen() {
printf("\nI am in prototypeAST function\n");
// Make the function type: double(double,double) etc.
std::vector<Type*> Doubles(size,
Type::getInt1Ty(getGlobalContext()));
printf("\nI am in prototypeAST function's 1\n");
FunctionType *FT;
if(isFunInt)
FT = FunctionType::get(Type::getInt1Ty(getGlobalContext()),
Doubles, false);
else if(isFunVoid)
FT = FunctionType::get(Type::getInt1Ty(getGlobalContext()),
Doubles, false);
printf("\nI am in prototypeAST function's 2\n");
Function *F = Function::Create(FT, Function::ExternalLinkage, FnName, TheModule);
printf("\nI am in prototypeAST function's 3\n");
// If F conflicted, there was already something named 'Name'. If it has a
// body, don't allow redefinition or reextern.
if (F->getName() != FnName) {
// Delete the one we just made and get the existing one.
F->eraseFromParent();
F = TheModule->getFunction(FnName);
}
// Set names for all arguments.
unsigned Idx = 0;
for (Function::arg_iterator AI = F->arg_begin(); Idx != ArgNames.size();
++AI, ++Idx) {
AI->setName(ArgNames[Idx]);
}
printf("\nI am in prototypeAST function\n");
return F;
}
你能發佈一些更接近真正的C++代碼嗎? – juanchopanza
你好,歡迎來到stackoverflow.com。請閱讀[Stack Overflow問題清單](http://meta.stackexchange.com/questions/156810/stack-overflow-question-checklist)。您可能還想了解[SSCCE](http://sscce.org/)是什麼。 –
如果你真的有一個空構造函數,我建議你開始在那裏尋找問題。請記住,給同一個名字不會使它們成爲同一個事物。 – molbdnilo