用代码编译错误

时间:2015-03-16 03:51:54

标签: c++ compiler-errors

我的代码出现了一些奇怪的编译器错误。我已粘贴下面的代码和类定义。我试过谷歌搜索但无济于事;我得到的唯一一件事是我的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);
    }

这是Grade的定义:

    #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;
}

如果评估课中有任何逻辑问题,请告诉我。 我现在收到以下链接器错误:

/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

1 个答案:

答案 0 :(得分:0)

我怀疑你想说

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

而不是

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

现在,让我尝试解释一轮中的语法错误。如果你有一个类:

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);