文章目录
data:image/s3,"s3://crabby-images/3fbaf/3fbaf6e342aad96fae4915838a71ba24ff7daa88" alt=""
1.可变参数模板的介绍
1.1C语言中的可变参数
data:image/s3,"s3://crabby-images/e6e1d/e6e1d7b3d30e7f02dddee54caf992c487e03bfbe" alt=""
1.2C++98/C++11的类模板和函数模板
- C++98/03,类模版和函数模版中只能含固定数量的模版参数
- C++11的可变参数模板能够让您创建可以接受可变参数的函数模板和类模板
1.3可变参数的函数模板
data:image/s3,"s3://crabby-images/a2b0e/a2b0ef099108d1d3f489fd9140e9a994341fbc58" alt=""
data:image/s3,"s3://crabby-images/cd756/cd75616d134462723f3c51d4ff6319d80ce0e604" alt=""
cpp
void ShowList(Args... args)
{
//sizeof可以计算参数包中有几个参数
cout << sizeof...(args) << endl;
/*不支持
for (size_t i = 0; i < sizeof...(args); ++i)
{
cout << args[i] << " ";
}
*/
cout << endl;
}
int main()
{
string str("I am A!");
ShowList();
ShowList(65);
ShowList(65, 'A');
ShowList(65, 'A', str);
return 0;
}
data:image/s3,"s3://crabby-images/fa530/fa530289ff346ef4951d06b740a676ce932c111d" alt=""
1.4展开参数包
我们无法直接获取参数包args中的每个参数,只能通过展开参数包 的方式来获取参数包中的每个参数
递归展开
cpp
//当参数包个数为0时 最后一次函数调用需要有无参函数
void ShowList()
{
cout << endl;
}
//参数包含参数个数 >= 0
template <class T, class ...Args>
void ShowList(const T& single, Args... args)
{
cout << "ShowList(" << single << ", " << "参数包 含" << sizeof...(args) << "个参数)" << endl;
ShowList(args...);
}
int main()
{
string s("3");
ShowList(1, '2', s);
ShowList(1, '2', s, 4, '5', 6);
return 0;
}
data:image/s3,"s3://crabby-images/8c8e1/8c8e1219544bd7996e1d49783dd716e75b3e2e6a" alt=""
初始化列表展开
cpp
template<class T>
int Display(const T& single)
{
cout << single << " ";
return 0;
}
template <class ...Args>
void ShowList(Args... args)
{
int a[] = { Display(args)... };
//int a[] = { Display(arg1), Display(arg2), Display(arg3)...};
cout << "当前参数包共" << sizeof(a) / sizeof(a[0]) << "个参数" << endl;
}
int main()
{
string s("3");
ShowList(1, '2', s);
ShowList(1, '2', s, 4, '5', 6);
return 0;
}
data:image/s3,"s3://crabby-images/8b5b4/8b5b4b642ead1155cdfec6c2d82113f906ce1039" alt=""
2.可变参数模板的应用
data:image/s3,"s3://crabby-images/5e379/5e379507c95c448aafe8e4712da18e2a5903a23f" alt=""
cpp
class Date
{
public:
Date(int year = 1, int month = 1, int day = 1)
:_year(year)
, _month(month)
, _day(day)
{
cout << "Date(int year = 1, int month = 1, int day = 1)" << endl;
}
Date(const Date& d)
:_year(d._year)
, _month(d._month)
, _day(d._day)
{
cout << "Date(const Date& d)" << endl;
}
Date& operator=(const Date& d)
{
cout << "Date& operator=(const Date& d))" << endl;
return *this;
}
private:
int _year;
int _month;
int _day;
};
// template <class... Args>
// iterator emplace(const_iterator pos, Args&&... args);
// template <class... Args>
// void emplace_back(Args&&... args);
int main()
{
/// emplace的优势1
//没有区别
vector<int> v1;
v1.push_back(1);
v1.emplace_back(2);
//emplace_back的优势 此情况更高效
vector<pair<string, int>> v2;
v2.push_back(make_pair("A", 65));
v2.emplace_back(make_pair("A", 65));
v2.emplace_back("A", 65);
/// emplace的优势2
cout << "-------------- push_back --------------" << endl << endl;
list<Date> lt1;
lt1.push_back(Date(2022, 11, 16));
cout << endl;
cout << "------------- emplace_back -----------" << endl << endl;
lt1.emplace_back(2022, 11, 16);
return 0;
}
data:image/s3,"s3://crabby-images/65db8/65db81c65013fcb6f74594ef3d59376bd67f9c65" alt=""