标签:shared-state c templates static-members
我正在做一些可能很愚蠢的事情,但如果它奏效的话会很好.
我试图以一种方式专门化类型,我需要自己的查找结构本质上是全局的(但理想情况下封装为类变量),但我希望对象是类型安全的,因此它们是参数化的.
因此,基本上我有
template<class T, int N>
class SpecialArray
{
//...
private:
static map<string, internal_t> lookupTable
}
无论出于什么原因,我都没有想到,直到我去初始化lookupTable
当我说的时候
template <class T, int N>
SpecialArray<T,N>::lookupTable;
将会有许多不同的lookupTables附加到SpecialArray的各种实例化.
我怀疑它可能只是一个梦想而且正确的答案只是使它成为一个单独的全局单例对象,但是无论如何要使它只有一个查找表用于所有的SpecialArrays?
比如,在我心中的C(这不是真正的C)中,这就像是
template <class T, int N>
SpecialArray<*,*>::lookupTable;
……但遗憾的是,海湾合作委员会并未在我的脑海中编制C语言
有没有任何实际的方法来获得我想要的东西(在C 0x-land或某处)?我可能会遇到一些静态方法来处理这个问题,这些方法操纵这个查找表(它不跟踪类型或Ns).
…对不起,如果这没有任何意义.
在此先感谢您提供任何帮助或同情.
解决方法:
您可以添加一个非模板化的基类,并将lookupTable移动到该类中:
class Base
{
protected:
static map<string, internal_t> lookupTable
};
template<class T, int N>
class SpecialArray : Base
{
//...
};
标签:shared-state,c,templates,static-members 来源: https://codeday.me/bug/20191007/1868347.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。