而不是使用
std::vector<Object> ObjectArray;
我希望它是
MyArray<Object> ObjectArray;
保留所有std :: vector方法。 (如push_back(),reserve(),...等)
然而,使用
typedef std::vector MyArray;
不起作用。我应该使用模板吗?怎么样?
答案 0 :(得分:14)
你真正想要的是模板化的typedef。不幸的是,当前版本的C ++不支持这些,但它们将被添加到C ++ 0x中。
目前,这是一种可行的解决方法:
template<class T> struct My {
typedef std::vector<T> Array;
};
My<Object>::Array ObjectArray
这是否比直接使用std::vector
更好,我会留给你决定。
答案 1 :(得分:7)
从C ++ 11开始,您可以使用模板化类型别名
template <typename T>
using MyArray = std::vector<T>;
如果你想更通用,你可以使用一个可变参数模板(在矢量的情况下允许分配器而不必具体)
template <typename... Ts>
using MyArray = std::vector<Ts...>;
答案 2 :(得分:5)
另一种方式:
#include <vector>
template <typename T>
struct MyArray
:std::vector<T>
{
};
void func()
{
MyArray<int> my;
my.push_back(5);
MyArray<int>::iterator i;
}
为我编译,但你可能会发现一些事情 可用于矢量&lt;&gt;需要“拉起来” 进入MyArray。