提问者:小点点

用户定义的文字无法包含另一个文件


我有一个Komp类,其中有一个用户定义的文本constexpr Komp运算符“”_I(长双倍x),用于从例如Komp k=1+5.0_I;中生成一个Komp对象。

这在komp.cpp的main()中工作得很好,但是当我在testing.cpp(其中包含komp.h)中编写相同的语句时,我得到了下面的错误。 komp.h中的所有其他函数在testing.cpp中都可以很好地工作。 我希望用户定义的文字会像其他函数一样被包含。

为什么用户定义的文字在testing.cpp中不起作用,而其他函数却起作用?

错误:

Undefined symbols for architecture x86_64:
  "operator"" _i(long double)", referenced from:
      MyTestSuite::test5() in komp_testrunner-d3c20f.o
ld: symbol(s) not found for architecture x86_64

// komp.cpp
class Komp {
    private:
        double val1;
        double val2;
    public: 
        // ... Bunch of member-function headers
        constexpr Komp(const double x, const double y) : val1(x), val2(y) {}
        double v1() {return val1;}
        double v2() {return val2;}
};
// ... Bunch of member and non-member functions.
Komp operator+ (const double lhs, const Komp rhs) { // overloads + operator for: double + Komp
    return Komp(lhs+rhs.v1(), rhs.v2());
}
constexpr Komp operator""_i(long double x) { // To match i.e Komp k = 1 + 2.3_i
    return Komp(0.0, x);
}
constexpr Komp operator""_i(unsigned long long x) { // To match i.e Komp k = 1 + 2_i
    return Komp(0.0, x*1.0);
}
int main() { // Only here temporarily for testing purposes
    Komp k = 1 + 2.0_i; // Works here
}
// komp.h
#include <string>
#ifndef KOMP_H
#define KOMP_H
class Komp
{
    public: 
        double val1;
        double val2;
        // ...
        Komp(const double x, const double y);
};
// ...
Komp operator+ (const double lhs, const Komp rhs);
Komp operator ""_i(long double arg);
Komp operator ""_i(unsigned long long arg);
#endif  
#include "komp.h"
#include <cxxtest/TestSuite.h>

class Testing : public CxxTest::TestSuite {
  public:
    void literalTest () {
      Komp c = 3.0 + Komp(2.0, 2.0); // Works fine. No problem with overloading + operator
      Komp b = 5.0 + 2.0_i; // Causing an error
      Komp c = Komp(1.0, 2.0);
      TS_ASSERT(b != c); 
    }
};

共1个答案

匿名用户

此函数声明:

Komp operator ""_i(long double arg);

testing.cpp或包含komp.h的任何文件唯一可见的文件。 但是,您还没有在任何地方定义这个函数。

请注意,此定义:

constexpr Komp operator""_i(long double x) { // To match i.e Komp k = 1 + 2.3_i
    return Komp(0.0, x);
}

constexpr,因此它是一个不同的函数。 只需在komp.h中将函数声明为constexpr

另外,您已经在komp.cpp中定义了komp类,这是不必要的,如果更改了一个定义而不更改另一个定义,可能会导致麻烦。