gpt4 book ai didi

c++ - 扣除其他类型依赖的类型

转载 作者:太空宇宙 更新时间:2023-11-04 12:34:16 25 4
gpt4 key购买 nike

我有这种情况:

#include <vector>

template<typename T, typename U = T>
U f(T data) {
return U();
}

int main() {
std::vector<int> vec = {1,2,3};
return f<std::vector<int>, int>(vec);
}

T 始终是模板化类型,U 始终是 T 所依赖的类型。有没有办法从 T 获取 U 以便在 f 调用中不显式显示 int 两次?

我试过以下方法,但没有用:

#include <vector>

template<template<class> class T, class U>
U f(T<U> data) {
return U();
}

int main() {
std::vector<int> vec = {1,2,3};
return f<std::vector, int>(vec);
}

最佳答案

这里的问题是 std::vector 不只有一个模板参数。它还具有分配器类型的参数。要解决这个问题,您可以添加另一个模板参数,或者只使用可变参数模板模板参数,例如

template<template<class...> class T, class U>
U f(T<U> data) {
return U();
}

将用于

return f<std::vector, int>(vec);

甚至更好

return f(vec);

请注意,此行为已在 C++17 中更改。用DR: Matching of template template-arguments excludes compatible templates他们放宽了规则,

template<template<class> class T, class U>
U f(T<U> data) {
return U();
}

将在 C++17 模式下使用 gcc,在启用 -frelaxed-template-template-args 的情况下在 C++17 中使用 clang。

关于c++ - 扣除其他类型依赖的类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57103413/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com