たとえば次のようなテンプレート関数がある場合:
template<typename T>
void func(const std::vector<T>& v)
Tがポインターであるかどうかを関数内で判断できる方法はありますか、それともこれに別のテンプレート関数を使用する必要がありますか。
template<typename T>
void func(const std::vector<T*>& v)
ありがとう
実際、テンプレートは部分的なテンプレートの特殊化でそれを行うことができます。
template<typename T>
struct is_pointer { static const bool value = false; };
template<typename T>
struct is_pointer<T*> { static const bool value = true; };
template<typename T>
void func(const std::vector<T>& v) {
std::cout << "is it a pointer? " << is_pointer<T>::value << std::endl;
}
関数内でポインターに対してのみ有効なことを行う場合は、コンパイラーが関数全体を型チェックするため、別の関数のメソッドを使用する方が適切です。
ただし、これにはブーストを使用する必要があります。これには次のものも含まれます。 http://www.boost.org/doc/libs/1_37_0/libs/type_traits/doc/html/boost_typetraits/reference/is_pointer.html
C++ 11には、素敵な小さなポインタチェック関数が組み込まれています:std::is_pointer<T>::value
これはブール値のbool
値を返します。
から http://en.cppreference.com/w/cpp/types/is_pointer
#include <iostream>
#include <type_traits>
class A {};
int main()
{
std::cout << std::boolalpha;
std::cout << std::is_pointer<A>::value << '\n';
std::cout << std::is_pointer<A*>::value << '\n';
std::cout << std::is_pointer<float>::value << '\n';
std::cout << std::is_pointer<int>::value << '\n';
std::cout << std::is_pointer<int*>::value << '\n';
std::cout << std::is_pointer<int**>::value << '\n';
}