2017-10-30 9 views
0

私はラッパーAlgebraicTreeExpressionクラスを作成しようとしているC++の宿題に取り組んでいます入力文字列に基づいて代数方程式を解析して計算するための基本的なAlgebraicTreeNodeクラスの周り。Algebraic Tree Expression C++エラー:未解決の外部シンボル "Public:_thiscall AlgebraicTreeExpression ::〜AlgebraicTreeExpression(void)..."

Error LNK2019 unresolved external symbol "public: __thiscall AlgebraicTreeExpression::~AlgebraicTreeExpression(void)" ([email protected]@[email protected]) referenced in function _main 1 C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\CMakeLists.txt C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\Calc6.cpp.obj 

Error LNK2019 unresolved external symbol "public: __thiscall AlgebraicTreeExpression::AlgebraicTreeExpression(char const *)" ([email protected]@[email protected]@Z) referenced in function _main 1 C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\CMakeLists.txt C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\Calc6.cpp.obj 

Error LNK2019 unresolved external symbol "public: char * __thiscall AlgebraicTreeExpression::toString(void)const " ([email protected]@@QBEPADXZ) referenced in function _main 1 C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\CMakeLists.txt C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\IDE\Calc6.cpp.obj 

AlgebraicTreeExpression.cppの関連する部分は次のとおりです:私はあるそうだ3つのエラー

AlgebraicTreeExpression::AlgebraicTreeExpression(): 
    _root(new AlgebraicTreeNode()) { 
} 
AlgebraicTreeExpression::~AlgebraicTreeExpression() { 
    if (_root != 0) delete _root; 
} 
char* AlgebraicTreeExpression::toString() const { 
    return _root->AlgebraicTreeNode::toString(); 
} 
// parser constructor 
AlgebraicTreeExpression::AlgebraicTreeExpression(const char* expression): 
    _root(new AlgebraicTreeNode(expression)) { 
} 

AlgebraicTreeNode.cppの関連部分は以下のとおりです。

AlgebraicTreeNode::~AlgebraicTreeNode() { 
    delete this; 
} 

AlgebraicTreeNode::AlgebraicTreeNode() { 
    //Default Constructor 
    //this->id(); 
    //count(); 
    //_parent = (AlgebraicTreeNode*)0; 
    _childLeft = 0; _childRight = 0; 
    _type = AlgebraicTreeNodeType::INVALID; 
    _value = 0; 
} 

AlgebraicTreeNode::AlgebraicTreeNode(AlgebraicTreeNode& src) { 
    //Copy Constructor 
    if (src._childLeft != (AlgebraicTreeNode*)(0)) { 
     this->setChildLeft(src._childLeft); 
     AlgebraicTreeNode(_childLeft); 
    } 
    if (src._childRight != (AlgebraicTreeNode*)(0)) { 
     this->setChildRight(src._childRight); 
     AlgebraicTreeNode(_childRight); 
    } 
    if (src._type == AlgebraicTreeNodeType::NUMBER) { 
     _value = src._value; 
     _type = src._type; 
     _childLeft = 0; _childRight = 0; 
    } 
} 
void AlgebraicTreeNode::setChildLeft(AlgebraicTreeNode* childLeft) { 
    _childLeft = childLeft; 
    _childLeft->_parent = this; 
} 

void AlgebraicTreeNode::setChildRight(AlgebraicTreeNode* childRight) { 
    _childRight = childRight; 
    _childRight->_parent = this; 
} 
char* AlgebraicTreeNode::toString() const { 
    unsigned N = this->_toStringLength(); 
    char* str = new char[N]; 
    memset(str, '\0', N * sizeof(char)); 
    AlgebraicTreeNode::_toString(str); 
    return str; 
    return (char*)0; 
} 
AlgebraicTreeNode::AlgebraicTreeNode(const char* expression) { 
    unsigned length = _parseExpression(expression); 
} 

// returns length of parsed substring 
unsigned AlgebraicTreeNode::_parseExpression(const char* expression) { 
    static int integers[] = {0,1,2,3,4,5,6,7,8,9}; 
    std::vector<int> number(integers, integers + sizeof(integers)/sizeof(int)); 
    unsigned length = 0; 
    int i = 0; 
    std::vector<int>::size_type sz = number.size(); 


    if (*expression == '(') { 
     length += 1; 
     this->setChildLeft(new AlgebraicTreeNode()); 
     this->_value = 0; 

     length += this->_childLeft->_parseExpression(expression + length); 
     if (*(expression + length) == '+') { 
      this->_type = AlgebraicTreeNodeType::ADD; 
      length += 1; 
     } 
     else if (*(expression + length) == '-') { 
      this->_type = AlgebraicTreeNodeType::SUBTRACT; 
      length += 1; 
     } 
     else if (*(expression + length) == '*') { 
      this->_type = AlgebraicTreeNodeType::MULTIPLY; 
      length += 1; 
     } 
     else if (*(expression + length) == '/') { 
      this->_type = AlgebraicTreeNodeType::DIVIDE; 
      length += 1; 
     } 
     this->setChildRight(new AlgebraicTreeNode()); 
     length += this->_childRight->_parseExpression(expression + length); 
     length += 1; //Placeholder for) 
     return length; 
    } 
    while (i != sz) { 
     printf("%i, %i\n", atoi(expression), number[i]); 
     std::cout << typeid(atoi(expression)).name() << typeid(number[i]).name() << std::endl; 
     if (atoi(expression + length) == number[i]) { 
      this->_type = AlgebraicTreeNodeType::NUMBER; 
      length += this->_parseNumber(expression + length); 
      return length; 
     } 
     i++; 
    } 
    return length; 
} 

unsigned AlgebraicTreeNode::_parseNumber(const char* expression) { 
    //unsigned length = 0; 
    char *endptr; 
    double value = strtod(expression,&endptr); 
    this->_value = value; 
    unsigned length = endptr - expression; 
    return length; 
} 
unsigned AlgebraicTreeNode::_toStringLength() const { 
    unsigned length = 1024; 

    return length; 
} 
unsigned AlgebraicTreeNode::_toString(char* str) const { 
    unsigned ntemp = 0; 
    if (this->_type == INVALID) { 
     return 0; 
    } 
    if (isOperation()) { 

     ntemp += sprintf((str + ntemp), "("); 

     if (this->_childLeft != (AlgebraicTreeNode*)0) { 

      ntemp += this->_childLeft->_toString(str + ntemp); 
     } 
     if (_type == ADD) { 
      ntemp += sprintf((str + ntemp), "+"); 
     } 
     else if (_type == SUBTRACT) { 
      ntemp += sprintf((str + ntemp), "-"); 
     } 
     else if (_type == MULTIPLY) { 
      ntemp += sprintf((str + ntemp), "*"); 
     } 
     else if (_type == DIVIDE) { 
      ntemp += sprintf((str + ntemp), "/"); 
     } 
     if (this->_childRight != (AlgebraicTreeNode*)0) { 
      ntemp += this->_childRight->_toString(str + ntemp); 
     } 
     ntemp += sprintf((str + ntemp), ")"); 
    } 
    else if (isNumber()) { 
     double thisvalue = this->_value; 
     ntemp += sprintf((str + ntemp), "%.0f", thisvalue); 
    } 
    return ntemp; 
} 

ですおそらく小さな修正が、どんな助けでもありがとう!

答えて

0

あなたはAlgebraicTreeExpression.cppオブジェクトファイルとリンクしていますか? (つまり、MSVCの場合は同じプロジェクト内にある必要があります。ライブラリである場合は、リンクすることを指定する必要があります)。

それ以外

、こちらを参照:ところでUnresolved external symbol in object files

AlgebraicTreeNode::~AlgebraicTreeNode() { 
    delete this; 
} 

それをしないでください、(あなたがここにあるようデストラクタ内からdeleteを呼び出す周りではない他の方法)デストラクタと空きメモリを呼ぶであろう、代わりにオブジェクト上deleteを呼び出します。

(これは、オブジェクトがスタック上に作成された場合に特に苦戦します)

関連する問題