今天要说的是C++使用可变参数的方式,包括std::initializer_list<T>模板类、可变参数模板。


    std::initializer_list<T>(<initializer_list>)

    是C++11新标准引入的初始化的列表,是一个模板类,可通过{...}形式传入并构造,这里介绍使用可变参数的情况:

#include <initializer_list> 
#include <iostream>
#include <string>


using std::string;
using std::cout;
using std::endl;
template<typename T> using initializer_list = std::initializer_list<T>;


void func(initializer_list<const string> L)
{
    
    cout << L.size() << endl;
    
    
    for (auto a = L.begin(); a != L.end(); ++a)
    {
        cout << *a << " ";
    }
    cout << endl;
}

int main()
{
    func({"123","asd","zmh"});
    return 0;
}

有个特点是初始化列表存储的类型是固定的,如果传入不可支持类型转换则编译错误


    可变参数模板

    可变模板参数是C++11新标准引入的,是可接收可变数目参数模板的模板函数和模板类,可变数目的参数是参数包:模板参数包(template<typename... T>)、函数参数包(T... type),与初始化列表不同的是可以接收不同类型的参数,但由于是模板则不支持分离编译,且用法较复杂,这里介绍可变参数模板的模板函数: 

    



#include <iostream>
using std::cout;
using std::endl;
using std::string;


template <typename T>
void func(const string &s1,const T &s2)
{
    cout << s1 << " " << s2 << endl;
}


template <typename... T> 
void func(const string &s, const T&... t)
{
    cout << sizeof...(t) <<endl; 
    cout << s << " ";
    
    func(t...); 
}
#include "a.h"

int main()
{
    func("123","asd","zmh"); 
    return 0;
}

此处实参可以不使用{... , ... , ...}方式传入。

可变参数模板有另一个主要用处,可以用于模板转发。