【发布时间】:2020-07-20 10:52:39
【问题描述】:
template <const long long int lx, const long long int ly, const long long int lz, const long long int cx, const long long int cy, const long long int cz> class rtH{
public: static const long long int sqlc=cx*cx+cy*cy+cz*cz;
static const long long int ldc=lx*cx+ly*cy+lz*cz;
};
template <const long long int lx, const long long int ly, const long long int lz, const long long int cx, const long long int cy, const long long int cz, const long long int r> class rt{
public: static const long long int d=rtH<lx,ly,lz,cx,cy,cz>::ldc-sqrt<rtH<lx,ly,lz,cx,cy,cz>::ldc*rtH<lx,ly,lz,cx,cy,cz>::ldc-(rtH<lx,ly,lz,cx,cy,cz>::sqlc-r*r),20>::value
;
};
int main(){return rt<1,1,1,1,1,1,1>::d;}
编译器不会抱怨实例化 rt,因此它知道 lx,ly,lz,cx,cy,cz,r 是编译时常量。在 rtH 中,我将 sqlc 和 ldc 定义为 const。这些 const 变量只依赖于编译时常量,所以它们也应该是编译时常量,对吧?如果是这样,为什么编译器会抱怨 sqrt 的参数不是编译时常量?
注意:sqrt 可以在其他地方使用。
【问题讨论】:
-
变量未定义为编译时常量。您需要使用
constexpr而不是const。还写const long long int作为模板参数是荒谬的多余。写long long或std::int64_t(或写在别处using std::int64_t并将其缩短为int64_t)。 -
const只是表示程序不可修改,并不意味着“编译时”。constexpr是一个不同的关键字,当应用于变量时,它意味着编译时常量。 -
@ZuodianHu 将其作为答案发布