假设我有这样的事情:
struct EmptyClass{};
template<typename T1, typename T2 = EmptyClass,
typename T3 = EmptyClass, typename T4 = EmptyClass,
..., typename T20> class PoorMansTuple {
T1 t1;
T2 t2;
...
T20 t20;
};
现在,每个PoorMansTuple可能浪费多达19bytes。
问题是:
1)有没有办法创建一个大小为0的类?
2)有没有办法有条件地定义变量?有点像:
T1 t1;
if (T2 != EmptyClass) T2 t2; // pseudo code
if (T3 != EmptyClass) T3 t3; // ...
谢谢!
预先使用黑魔法宏。
我在MacOSX上使用g ++。
答案 0 :(得分:4)
部分专业化可能是您正在寻找问题的第一部分。这个程序
#include <string>
#include <iostream>
struct EmptyClass {};
template<typename T1, typename T2>
class Tuple
{
T1 t1;
T2 t2;
};
template<typename T1>
class Tuple <T1, EmptyClass>
{
T1 t1;
};
int main (void)
{
Tuple<std::string, std::string> two;
Tuple<std::string, EmptyClass> one1;
Tuple<std::string> one2;
std::cout << "<string, string>: " << sizeof(two) << std::endl;
std::cout << "<string, empty> : " << sizeof(one1) << std::endl;
std::cout << "<string> : " << sizeof(one2) << std::endl;
return 0;
}
打印
<string, string>: 32
<string, empty> : 16
<string> : 16
答案 1 :(得分:1)
1)不,因为类的实例没有内存地址。它需要至少1个字节才能有地址。 - 也就是说,没有任何实例和直接引用的类(例如仅在模板生成时使用)将没有大小,因为它不在编译的程序中。
2)不是没有宏......或者可能是模糊的黑色艺术,只有boost.org ninjas可以掌握。我听说过编译时“if”的想法,但它目前还没有AFAIK语言的任何标准。这样就可以了。如前所述,也许有一个技巧可以做到。
答案 2 :(得分:1)
答案 3 :(得分:1)
结帐boost::tuple
和boost::compressed_pair
。类不能具有sizeof 0,但是存在“空基类”优化的概念。呃,我只想链接到我以前的一个答案,这在IMO非常相关:What is std::pair?