C++中为什么不要使用可变参数
本篇内容主要讲解"C++中为什么不要使用可变参数",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"C++中为什么不要使用可变参数"吧!
F.55 不要使用可变参数
Reason(原因)
从va_arg中读出内容的处理假设实际传递的数据类型是正确的。传递可变参数的处理假设数据会按照正确的类型被读取。由于通常这两种假设都不能在语言中强制达成安全,只能依靠编程规范以保证其正确。因此说都是脆弱的。
Example(示例)
int sum(...) {
// ...
while (/*...*/)
result += va_arg(list, int); // BAD, assumes it will be passed ints
// ...
}
sum(3, 2); // ok
sum(3.14159, 2.71828); // BAD, undefined
template
auto sum(Args... args) { // GOOD, and much more flexible
return (... + args); // note: C++17 "fold expression"
}
sum(3, 2); // ok: 5
sum(3.14159, 2.71828); // ok: ~5.85987
译者注:代码中使用了两种现代C++的新特性,一个是C++11中引入的可变参数模板(variadic template),另一个是C++17引入的折叠表达式(fold expression)。
Alternatives(备选方案)
overloading
重载
variadic templates
可变参数列表
variant
argumentsvariant(C++17引入的变体数据,译者注)类型参数。
initializer_list
(homogeneous)初始化列表(同类数据的情况)(C++11引入)
Note(注意)
定义一个...参数在无法决定实际参数类型时一种有用的技术,尤其是定义可以接受任何东西的函数以便在重载版本中禁止"任何其他的东西"或者在模板元程序中表示包罗万象的容器。
Enforcement(实施建议)
Issue a diagnostic for using
va_list
,va_start
, orva_arg
.发起对使用va_list,va_start或者va_arg的检查。
Issue a diagnostic for passing an argument to a vararg parameter of a function that does not offer an overload for a more specific type in the position of the vararg. To fix: Use a different function, or
[[suppress(types)]]
.发起针对以下情况的检查:向函数的可变参数可变参数传递单独的实参,而且不存在在可变参数位置定义了特定数据类型参数的重载函数。
修改建议:使用不同的函数或者[[抑制((类型准则群组))]]
到此,相信大家对"C++中为什么不要使用可变参数"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!