【发布时间】:2011-06-30 02:01:54
【问题描述】:
假设我有一个存储前 10 个素数的数组,如下所示:
const int primes[] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29};
只要我有 1 个 .cpp 文件,这一切都非常简单。但是,如果我有多个 .cpp 文件,我真的不知道将这个数组放在哪里。
一个明显的解决方案是:
// primes.h:
extern const int primes[10];
// primes.cpp:
extern const int primes[] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29};
但是,这样做的问题是素数数组不再是编译时间常数。假设 x.cpp 想要进行一些涉及素数 [k] 的繁重计算,其中 k 是编译时间常数,它必须进行实际的内存查找。我不喜欢那样。
那么我应该把这个数组放在哪里:
- 在二进制文件中只有一次(不是每个 .cpp 文件一次)
- array[SOME_CONSTANT] 也是编译时常量
编辑
这个怎么样?
inline int prime(int i) {
static const int primes[] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29};
return primes[i];
}
PS:即使是上面的“明显解决方案”也花了我相当长的时间来写。显然 const 变量默认具有内部链接,所以我必须在 primes.cpp 文件中添加“extern”才能使其工作。
【问题讨论】:
-
在我看来,无论您做什么,数组成员实际上都不能用作编译时常量。为此,您可能需要更高级的元编程类型。
-
@UncleBens 我并不是真的想像“int a[b[5]];”那样使用它,其中 b[5] 确实必须是编译时常量,我只是想要编译器预先计算诸如 sin(sqrt(b[5]));. 之类的东西
-
只要您不需要
sizeof (primes)或指向整个数组的指针,您的新解决方案(我假设改编自我的一个建议)应该可以完美运行。你可以返回一个const int&,而不是让你得到一个指向数组的指针。 -
"所以我必须在 primes.cpp 文件中添加 "extern" 才能使其工作。" 你不是总是在 x.cpp 中包含 xh 吗?
标签: c++ lookup-tables compile-time-constant