
3.1.9崭新的Template特性
Variadic Template 可变参数模板
void print()
{
} template <typename T, typename… Types>
void print (const T& firstArg, const Types&… args)
{
std::cout<<firstArg<<std::endl;
print(args);
}
如上,如果传人1或多个实参,上述的function template就会被调用,区分第一个实参,允许第一实参被打印,然后递归调用print()并传入其余实参。必须提供一个nontemplate重载函数print(),才能结束整个递归动作。
Alias Template 带别名的模板
template <typename T>
using Vec = std::vector<T,MyAlloc<T>>;
后,可以这样声明:
Vec<int> coll;
reference wrapper
官方的解释是这样的:
Class that emulates a reference to an element of type T, but which can be copied (it is both copy-constructible and copy-assignable).
实例:
std::vector<std::reference_wrapper<Item>> books; // elements are references Item f("Faust",12.99);
books.push_back(f); // insert book by reference
for (const auto& book : books) {
std::cout << book.get().getName() << ": "
<< book.get().getPrice() << std::endl;
}
注意book.get().getName(),循环体中book被声明为处理“类型为Item&”的元素,用它直接调用成员函数前要调用get()。
C++11开始支持数组的begin和end,具体用法为:
int ia[]={,,,,,,,};
int *b=begin(ia);
int *e=end(ia);