Answers:
港九一个编译单元(通常.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.
};
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;
(*)根据标准,如果将其用于除整数常量表达式以外的代码中,则必须i
在类定义(如j
is)之外定义。有关详细信息,请参见下面的David评论。
i
需要定义它,对吗?在这种情况下,您不能说存在错误,因为没有足够的上下文可以确定-或严格地说,如果没有其他代码,则上面的示例是正确的。现在,我很感谢您的评论(+1),我仍然在学习自己的东西!因此,我将尝试在答案中阐明这一点,请让我知道是否更好……
int f() { return 42; } class foo { static const int i = f(); /* Error! */ }
请注意,C ++ 11允许调用'constexpr'函数:constexpr int f() { return 42; } class foo { static const int i = f(); /* Ok */ }
static const int ARRAYSIZE
在头文件中仅初始化整数值(例如),因为它们通常在类头中用于定义某些内容,例如数组的大小。非整数值在实现文件中初始化。
i
必须在cpp中定义。§9.4.2/ 4 如果静态数据成员是const整型或const枚举类型,则其在类定义中的声明可以指定一个常量初始化器,该初始化器应为整数常量表达式(5.19)。在这种情况下,成员可以出现在整数常量表达式中。如果在程序中使用了该成员,则该成员仍应在名称空间范围内进行定义,并且名称空间范围定义不应包含初始化程序。