在 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&&...) {} }; }
以上是如何在 C 中对所有可变参数模板参数调用函数?的详细内容。更多信息请关注PHP中文网其他相关文章!