我正在使用libgc,它是C和C++的垃圾收集器。
为了使STL容器可以被垃圾回收,必须使用gc_allocator。

而不是写

std::vector<MyType>

一个要写
std::vector<MyType,gc_allocator<MyType> >

有没有办法定义类似
template<class T> typedef std::vector<T,gc_allocator<T> > gc_vector<T>;

我前一段时间检查过,发现这是不可能的。但是我可能错了,或者可能还有其他方法。

以这种方式定义 map 尤其令人不愉快。
std::map<Key,Val>

变成
std::map<Key,Val, std::less<Key>, gc_allocator< std::pair<const Key, Val> > >

编辑:尝试使用宏后,我发现以下代码将其破坏:
#define gc_vector(T) std::vector<T, gc_allocator<T> >
typedef gc_vector( std::pair< int, float > ) MyVector;

模板化类型定义中的逗号被解释为宏参数分隔符。

因此,似乎内部类/结构是最佳解决方案。

这是有关如何在C++ 0X中完成的示例
// standard vector using my allocator
template<class T>
using gc_vector = std::vector<T, gc_allocator<T> >;

// allocates elements using My_alloc
gc_vector <double> fib = { 1, 2, 3, 5, 8, 13 };

// verbose and fib are of the same type
vector<int, gc_vector <int>> verbose = fib;

最佳答案

您可以使用using例如使用C++ 11模板化类型别名。像这样

template <typename T>
using gc_vector = std::vector<T, gc_allocator<T>>;

注意:我知道这是一个古老的问题,但是由于它有很多反对意见,而且随着它出现在搜索结果中,我认为它应该得到更新的答案。

关于c++ - 模板化的typedef?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/649718/

10-09 13:27