ChatGPT解决这个技术问题 Extra ChatGPT

类模板中的静态成员初始化

我想这样做:

template <typename T>
struct S
{
    ...
    static double something_relevant = 1.5;
};

但我不能,因为 something_relevant 不是整数类型。它不依赖于 T,但现有代码依赖于它是 S 的静态成员。

由于 S 是模板,我不能将定义放在编译文件中。我该如何解决这个问题?

也适用于 std::string 类型
自 c++11 起,关键字 inline 已更改,因此可以在声明时初始化静态变量。所以这个声明看起来像“inline static double something_relevant = 1.5;”
@user8991265 我相信内联变量从 C++17 开始可用,而不是 C++11。

s
sbi

只需在标题中定义它:

template <typename T>
struct S
{
    static double something_relevant;
};

template <typename T>
double S<T>::something_relevant = 1.5;

由于它是模板的一部分,与所有模板一样,编译器将确保它只定义一次。


@sbi:它不违反单一定义规则吗?
不,如果我们在谈论模板,则不是。否则函数模板也会这样做。
@sbi,@Prasoon:实际上 Prasoon 似乎是第一个。但由于对 ODR 的评论(这是我最关心的问题),我仍然接受 sbi。
@sbi 只需将鼠标悬停在文本上 :)
@Johannes:该死,我在这里待了一年,但我不知道!我还缺少什么? (当我发现当我点击投票数时出现的两个数字不是错误,而是一个功能时,我仍然记得那种耻辱。)<goes_playing>哇,当我将鼠标悬停在你的名字上时,我看到了你的代表!我也不知道那个。 @Prasoon:不,你是对的,我反复到达现在的位置。 (这就是为什么我对你的答案投了赞成票,顺便说一句。)
x
xaxxon

从 C++17 开始,您现在可以将静态成员声明为 inline,这将在类定义中定义变量:

template <typename T>
struct S
{
    ...
    static inline double something_relevant = 1.5;
};

直播:https://godbolt.org/g/bgSw1u


这是一个很好的答案。简短而准确。有关详细信息,另请参阅 en.cppreference.com/w/cpp/language/static#Static_data_members
P
Prasoon Saurav

这将起作用

template <typename T>
 struct S
 {

     static double something_relevant;
 };

 template<typename T>
 double S<T>::something_relevant=1.5;

我没有定义 something_relevant 变量(我删除了 template<typename T> double S<T>::something_relevant=1.5;) 编译器抛出错误。你能告诉我是什么原因吗?
这将在包含这些行的每个模块中引入变量的副本。又如何确保变量只存在于一个共享模块中,而其他模块引用它呢?