c++ - 代码编译错误

这个问题在这里已经有了答案:





What is an undefined reference/unresolved external symbol error and how do I fix it?

(37 个回答)


7年前关闭。




我的代码出现了一些奇怪的编译器错误。我在下面粘贴了代码和类定义。我试过用谷歌搜索,但无济于事;我唯一得到的是我的 Grade 构造函数在某处是错误的。

这些是构建错误:

Evalution.cpp: In constructor ‘Evaluation::Evaluation(char*, Grade*)’:
Evalution.cpp:20:55: error: no match for call to ‘(Grade) (char [30],    double*)’
     Grades[num](Graded[num].comments,&Graded[num].mark);

这是评估的定义:
    #include <iostream>
    #include <cstring>
    #include "Evalution.h"
    Evaluation::Evaluation(){
        code[0]='\0';
        for(int num=0;num<50;num++)
            Grades[num];
    }   
    Evaluation::Evaluation(char coursecode[],Grade Graded[]){
            if(coursecode[0]='\0'&& strlen(coursecode) !=6) {
                for(int num=0;num<50;num++){
                    if(Graded[num].mark < 0)
                Evaluation();
                numgrades=num;
            }
        }
            else{
                strcpy(code,coursecode);
                for(int num=0;num < 50; num++) {
                    Grades[num](Graded[num].comments,&Graded[num].mark);
                    numgrades=num;

            }
        }
    }
    bool Evaluation::empty()const{
        if(code[0]=='\0'){
            for(int num=0;num<numgrades;num++){
                if(Grades[num].mark < 0)
                    return  true;
            }
        }
        else
            return false;
    }
    float Evaluation::calculateAverage() const{
        float total=0;
        for(int num=0;num<=numgrades;num++)
            total+=Grades[num].mark;
        return total/numgrades;
    }
    void Evaluation::display(std::ostream& os) const{
        if(empty())
            return;
        else{
            float average=calculateAverage();
            os<< code << average <<endl;
            for(int num=0;num<=numgrades;num++)
                Grades[num].display(std::cout);
        }
    }   
    bool operator<(const Evaluation& tested, double pass){
        float average=tested.calculateAverage();
        if (average < pass)
            return true;
        else 
            return false;
    }
    std::ostream& operator<<(std::ostream& os, const Evaluation& input){
        os<<input.display(&os);
    }

这是等级的定义:
    #include <iostream>
    #include "Grade.h"
    #include <cstring>
    using namespace std;
    Grade::Grade(){
        mark = 0;
        comments[0] = '\0';
    }
    Grade::Grade(char commented[], double &marked){
        if (commented == '\0' && marked < 0)
            Grade();
        else{
            strcpy(comments, commented);
            mark = marked;
        }
    }
double Grade::get() const{
    return mark;
}
void Grade::display(std::ostream& os) const{
    os << mark <<"-"<< comments << endl;
}

此外,如果评估类(class)中有任何逻辑问题,请告诉我。
我现在收到以下链接器错误:
/tmp/cc1F2Crw.o: In function `main':
 15 w7part2.cpp:(.text+0x44): undefined reference to `Grade::Grade(char*, double)'
 16 w7part2.cpp:(.text+0x6e): undefined reference to `Grade::Grade(char*, double)'
 17 w7part2.cpp:(.text+0x98): undefined reference to `Grade::Grade(char*, double)'
 18 w7part2.cpp:(.text+0xb3): undefined reference to `Evaluation::Evaluation(char*, Grade*)'
 19 w7part2.cpp:(.text+0xc7): undefined reference to `Evaluation::display(std::ostream&) const'
 20 w7part2.cpp:(.text+0xef): undefined reference to `operator<(Evaluation const&, double)'
 21 collect2: error: ld returned 1 exit status

最佳答案

我怀疑你是想说

Grades[num] = Grade(Graded[num].comments, Graded[num].mark);

代替
Grades[num](Graded[num].comments,&Graded[num].mark);

现在,让我尝试以一种迂回的方式解释语法错误。如果你有这样的类(class):
class foo
{
   public:
      void operator()(int, int) {}
};

你可以使用:
Foo foos[10];
foos[0](10, 20);   // This calls the operator() function of the class.

在你的陈述中,你有:
Grades[num](Graded[num].comments,&Graded[num].mark);
^^ Like foos[num]

Grades[num](Graded[num].comments,&Graded[num].mark);
           ^^ Like (10, 20)

由于Grade没有这样的功能,编译器让您知道,但使用的语言对您来说并不明显。

编辑

现在我已经考虑过了,我不确定您要做什么。如果您使用:
Grades[num] = Grade(Graded[num].comments, Graded[num].mark);

这与自我分配是一回事。

编辑 2

要处理第二条错误消息,请使用:
// Evaluation::display(...) returns void.
// Can't use:
// os<<input.display(...);
// Also, lose the & from the argument.
input.display(os);

代替
os<<input.display(&os);

https://stackoverflow.com/questions/29069387/

相关文章:

c++ - 模板化 BST 方法的返回值问题

java - 出现错误: No enclosing instance of type **** is

c++ - '' *2之前的解析错误

exception - 捕获 block 避免编译错误?

c++ - header 多重重新定义

android - Android代码抛出错误

java - 未知的Java类错误

c++ - 默认构造函数编译错误,预期的ID不合格

oracle - Oracle函数编译错误PLS-00103(遇到符号 “SELECT”…)

java - 无法编译Java代码