make_tuple
功能说明
make_tuple是一个实用的函数模板,其作用在于便捷地创建tuple对象。它可以自动推断元素的类型,使代码更简洁,也可以构造元素列表。
函数原型
1 2 | template <typename ...Tps> __aicore__ inline constexpr tuple<unwrap_decay_t<Tps>...> make_tuple(Tps&& ...args); |
参数说明
参数名 |
含义 |
---|---|
Tps... |
Tps...为传入tuple的模板参数包,代表传递给make_tuple的参数类型,参数个数范围为[0, 64]。 |
args |
args...是函数参数包,代表传递给make_tuple的实际参数,参数个数范围为[0, 64]。 |
支持的型号
约束说明
- tuple实例化深度为64,即支持64个元素以内的基础数据类型的聚合。
- make_tuple中需要特别指定数据类型的元素,必须对该元素的数据类型增加强转,否则由编译器自行推断,可能与预期不符。
- 不支持数组等可变长度的数据类型。
- 不支持隐式转换构造函数。
返回值
一个tuple对象,此对象包含传递的参数副本。
调用示例
1 | AscendC::Std::tuple<uint32_t, float, bool> test = AscendC::Std::make_tuple(22, 3.3, true); |
更多调用示例请参见示例。
父主题: 容器函数