Как пройти рекурсивный шаблон класса - PullRequest
1 голос
/ 08 апреля 2019

Я хочу пройти шаблон класса с несколькими глубинами.в C ++ 98 (до C ++ 11).

псевдо-код.

template<typename T>
std::string find_type(T *ptr);
template <>
std::string find_type<std::string>(int *ptr)
{
  return "string";
}
template <>
std::string find_type<std::list>(std::list *ptr)
{
  return "list";
}
template <>
std::string find_type<std::vector>(std::vector *ptr)
{
  return "vector";
}

template<T>
std::string somefunction(T *ptr)
{
 if(T is template class)
   return find_type + " " + somefunction(ptr);
else
 return find_type(ptr);
}

Я хочу получить результат ниже:

 std::list<std::string> test;
somefunction(test) -> I NEED "list string";

 std::list<std::vector<std::string> > test2;
somefunction(test) -> I NEED "list vector string";

Как я могу сделатьэто?

Я хочу сделать сериализатор класса шаблонов.

Спасибо.

1 Ответ

3 голосов
/ 08 апреля 2019

Я считаю, что этот результат не может быть достигнут через специализацию функции шаблона (поскольку частичная специализация функции не допускается).Но это может быть достигнуто с помощью специализаций шаблонного класса:

#include <vector>
#include <list>
#include <string>

template <typename T>
struct TypePrinter;

template <typename T>
struct TypePrinter<std::vector<T> >
{
    static std::string print()
    {
        return "vector " + TypePrinter<T>::print();
    }
};

template <typename T>
struct TypePrinter<std::list<T> >
{
    static std::string print()
    {
        return "list " + TypePrinter<T>::print();
    }
};

template <>
struct TypePrinter<std::string>
{
    static std::string print()
    {
        return "string";
    }
};

int main()
{
    std::string i = TypePrinter<std::list<std::string> >::print();
    std::string ii = TypePrinter<std::list<std::vector<std::string> > >::print();
}
...