【发布时间】:2017-07-11 18:37:04
【问题描述】:
我想使用它们的 ::iterator 成员类型将 c++ 容器解析为另一个对象。迭代器成员类型指向单一类型对象(向量、队列等)的容器将变成类列表对象,而迭代器成员类型指向std::pair的容器将变成类地图对象.
我正在尝试编写一个成员函数来检测后一种容器,但它不起作用。到目前为止,这是我所拥有的:
#include <tuple>
#include <iterator>
#include <type_traits>
template <typename T>
struct is_pair : std::false_type { };
template <typename T, typename U>
struct is_pair<std::pair<T, U>> : std::true_type { };
template <typename T>
constexpr bool is_pair_v = is_pair<T>::value;
template <typename...>
struct is_mapping : std::false_type { };
template <typename Container>
struct is_mapping<Container, std::enable_if_t<
is_pair_v<std::iterator_traits<typename Container::iterator>::value_type>
>> : std::true_type { };
template <typename T>
constexpr bool is_mapping_v = is_mapping<T>::value;
#include <map>
#include <vector>
#include <iostream>
int main() {
std::cout << "is_pair:" << std::endl;
std::cout << "Map: " << is_pair_v<std::iterator_traits<std::map<int, int>::iterator>::value_type> << std::endl;
std::cout << "Vector: " << is_pair_v<std::iterator_traits<std::vector<int>::iterator>::value_type> << std::endl;
std::cout << std::endl;
std::cout << "is_mapping:" << std::endl;
std::cout << "Map: " << is_mapping_v<std::map<int, int>> << std::endl;
std::cout << "Vector: " << is_mapping_v<std::vector<int>> << std::endl;
}
由于某种原因,is_mapping_v 始终为 false,代码导致以下输出:
$ g++ -std=c++14 temp.cc && ./a.out
is_pair:
Map: 1
Vector: 0
is_mapping:
Map: 0
Vector: 0
我的代码有什么问题?
注意:这不是Checking if a type is a map 的副本。该问题的答案使用::key_type 和::mapped_type 成员来检测地图(对于std::multimap 等类,它会失败)。我还在代码后面明确使用了迭代器指向std::pairs 的事实,因此检查它更有意义。
【问题讨论】:
标签: c++ template-meta-programming