我有一个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);
}
};
此函数声明:
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
类,这是不必要的,如果更改了一个定义而不更改另一个定义,可能会导致麻烦。