我的 class 无法识别用户定义的文字运算符

User-defined literal operator isn't recognised in my class

我写了一个 class,它使用文字运算符来指示要在物理应用程序中使用的测量误差。我已经定义了一个文字 ""_err,它将 long double 作为参数,returns 是一个名为 Error 的结构。例如,1.3_err.

此文字的 friend 声明放在头文件 TStat.h 中,定义放在 TStat.cpp 中,您将在下面的代码中看到。

但是,在使用 b = 0.4_err 这样的示例进行编译时出现错误,其中 bError。在错误中它说找不到文字运算符。您可以查看本题末尾的错误信息。

我尝试了很多组合,比如在内部或外部定义文字等。我搜索过类似的问题,但代码中的一切似乎都很好,就像许多教程和其他 C++ 资源所描述的那样。

作为一名粒子物理学家,我使用了一个由 CERN 开发的名为 ROOT 的 C/C++ 库,它实际上是一个 C/C++ 解释器。在那里,我可以毫无错误地使用这个 class(我根本没有使用任何 ROOT class)。但是,当我用 g++c++11 标志编译我的代码时,找不到与文字匹配的内容。

这是头文件:

#ifdef TSTAT_H
#define TSTAT_H

namespace TStat {
    struct Error {
        // ...
    }

    class Double {
        // constructors, etc.
        // ...

        friend Error operator "" _err (long double);
    }
}

这是 TStat.cpp 文件:

#include "TStat.h"

using namespace TStat;

// ...

TStat::Error operator"" _err(long double err) {
    TStat::Error error;
    // ...
    return error;
}

在终端中使用以下命令编译时(我使用的是 MacOS)

g++ -Wall -g -std=c++11 example.cpp TStat.cpp -o example.exe

我收到一条错误消息

example.cpp:6:12: error: no matching literal operator for call to
  'operator""_err' with argument of type 'long double' or
  'const char *', and no matching literal operator template
b = 0.4_err;

对于这样的 example.cpp:

#include "TStat.h"

using namespace TStat;

int main() {
    Error b;
    b = 0.4_err;

    return 0;
}

A friend 声明不会将声明的名称带入任何其他范围。在这种情况下,它甚至不会将名称带入 class 本身的范围内:

[class.friend]/7 A friend function defined in a class is in the (lexical) scope of the class in which it is defined. A friend function defined outside the class is not (6.4.1).

但这与显示的案例无关。 main 不会在任何 class.

中看到任何 friend 声明

最简单的解决方法是在任何 class.

之外的顶层在 TStat.h 中声明 operator "" _err