Sử dụng kỹ thuật này:
#include <type_traits>
template< typename T, typename = void >
class Size
{
unsigned int operator() (T) {return sizeof(T);}
};
template< typename T >
class Size< T, typename std::enable_if<
std::is_same< T, char* >::value ||
std::is_same< T, const char* >::value
>::type >
{
unsigned int operator() (T str) { /* your code here */ }
};
EDIT: Ví dụ về làm thế nào để xác định các phương pháp bên ngoài định nghĩa lớp.
EDIT2: Đã thêm trợ giúp để tránh lặp lại điều kiện có thể dài và phức tạp.
EDIT3: Trình trợ giúp được đơn giản hóa.
#include <type_traits>
#include <iostream>
template< typename T >
struct my_condition
: std::enable_if< std::is_same< T, char* >::value ||
std::is_same< T, const char* >::value >
{};
template< typename T, typename = void >
struct Size
{
unsigned int operator() (T);
};
template< typename T >
struct Size< T, typename my_condition<T>::type >
{
unsigned int operator() (T);
};
template< typename T, typename Dummy >
unsigned int Size< T, Dummy >::operator() (T)
{
return 1;
}
template< typename T >
unsigned int Size< T, typename my_condition<T>::type >::operator() (T)
{
return 2;
}
int main()
{
std::cout << Size<int>()(0) << std::endl;
std::cout << Size< char* >()(0) << std::endl;
std::cout << Size< const char* >()(0) << std::endl;
}
mà in
1
2
2
Nguồn
2013-02-17 22:00:32
Tôi không thuyết phục đây là một ý tưởng tốt. Điều gì về trường hợp mà bạn có một '(const) char *' mà không trỏ vào một chuỗi? –
Nó chỉ hoạt động để chỉ chuyên phiên bản 'const'? – Bingo
Không, sau đó khi bạn vượt qua một char không * nó không sử dụng chuyên môn. –