在 C 中,通常需要迭代可变参数模板参数并执行特定操作,例如调用一个函数。这可以使用以下任一方法来实现:
(f(args), ...);
但是,如果被调用的函数可能返回一个对象对于重载的逗号运算符,您应该使用:
((void)f(args), ...);
常见方法是利用列表初始化并在其中执行扩展:
{ print(Args)... }
由于 print() 返回 void,您可以通过返回 int 来解决该问题:
{ (print(Args), 0)... }
为了确保它适用于任意数量的参数,您可以使包始终至少有一个元素:
{ 0, (print(Args), 0)... }
您可以将此模式封装到可重用的宏中:
namespace so { using expand_type = int[]; } #define SO_EXPAND_SIDE_EFFECTS(PATTERN) ::so::expand_type{ 0, ((PATTERN), 0)... }
要处理重载的逗号运算符,可以修改宏:
#define SO_EXPAND_SIDE_EFFECTS(PATTERN) \ ::so::expand_type{ 0, ((PATTERN), void(), 0)... }
如果您担心不必要的内存分配,您可以定义一个支持列表的自定义类型 -初始化但不存储数据:
namespace so { struct expand_type { template <typename... T> expand_type(T&&...) {} }; }
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3