C++在哪里初始化静态const

Tho*_*mas 122 c++ static initialization constants

我上课了

class foo {
public:
   foo();
   foo( int );
private:
   static const string s;
};
Run Code Online (Sandbox Code Playgroud)

s源文件中初始化字符串的最佳位置在哪里?

squ*_*art 171

港九一个编译单元(通常.cpp文件)会做:

foo.h中

class foo {
    static const string s; // Can never be initialized here.
    static const char* cs; // Same with C strings.

    static const int i = 3; // Integral types can be initialized here (*)...
    static const int j; //     ... OR in cpp.
};
Run Code Online (Sandbox Code Playgroud)

Foo.cpp中

#include "foo.h"
const string foo::s = "foo string";
const char* foo::cs = "foo C string";
// No definition for i. (*)
const int foo::j = 4;
Run Code Online (Sandbox Code Playgroud)

(*)根据标准,如果在代码中使用它而不仅仅是整数常量表达式,则必须i在类定义之外定义(如jis).有关详细信息,请参阅下面David的评论.

  • 我已经投了赞成票,但在审查标准后,你的代码中出现了错误:`i`必须在cpp中定义*.§9.4.2/ 4*如果静态数据成员是const integer或const枚举类型,它在类定义中的声明可以指定一个常量初始化器,它应该是一个整型常量表达式(5.19).在这种情况下,成员可以出现在整数常量表达式中.如果在程序中使用该成员,并且命名空间范围定义不包含初始化程序,则该成员仍应在名称空间范围内定义.* (27认同)
  • 根据你对标准的引用,似乎`i`必须被定义*如果它被用在别的地方而不是在整数常量表达式中,对吧?在这种情况下,您不能说存在错误,因为没有足够的上下文可以确定 - 或者严格地说,如果没有其他代码,上面的示例是正确的.现在我很感激你的评论(+1),我还在自学!所以我会尝试在答案中澄清这一点,请让我知道它是否更好...... (3认同)
  • @Saksham例如调用一个函数,例如:`int f(){return 42; class foo {static const int i = f();/*错误!*/}`注意C++ 11允许调用'constexpr'函数:`constexpr int f(){return 42; class foo {static const int i = f();/*好的*/}` (3认同)
  • @squelart我阅读了文本,如果完全使用该成员,则必须提供定义 - 标准中的措辞并不将该要求限制为整数常量表达式。 (2认同)

Mic*_*urr 12

静态成员需要在文件范围或适当的命名空间中的.cpp转换单元中初始化:

const string foo::s( "my foo");
Run Code Online (Sandbox Code Playgroud)


ple*_*ndo 12

从 C++17 开始,内联说明符也适用于变量。您现在可以在类定义中定义静态成员变量:

#include <string>

class foo {
public:
   foo();
   foo( int );
private:
   inline static const std::string s { "foo" };
};
Run Code Online (Sandbox Code Playgroud)


GMa*_*ckG 10

在同一名称空间内的翻译单元中,通常位于顶部:

// foo.h
struct foo
{
    static const std::string s;
};

// foo.cpp
const std::string foo::s = "thingadongdong"; // this is where it lives

// bar.h
namespace baz
{
    struct bar
    {
        static const float f;
    };
}

// bar.cpp
namespace baz
{
    const float bar::f = 3.1415926535;
}
Run Code Online (Sandbox Code Playgroud)