2011-03-15 27 views
10

İkinci temayı std :: koşullu olarak nasıl değerlendirebilirim? Şimdi std::conditional sonraki iki ::type sTembel değerlendirme

template <typename T> 
struct false_case { 
    typedef typename std::conditional<T::one,_1,_2>::type type; 
}; 

struct always_null {typedef Null type;}; 

template<class T> 
struct X : 
    std::conditional<is_nulltype<T>::value, 
        always_null, 
        false_case<T> 
        >::type::type { ... }; 

Not:

#include "stdafx.h" 
#include <type_traits> 

struct Null{}; 
struct _1{enum {one = true,two = false};}; 
struct _2{enum {two = true, one = false};}; 

template<class T> 
struct is_nulltype 
{ 
    enum {value = false}; 
}; 

template<> 
struct is_nulltype<Null> 
{ 
    enum {value = true}; 
}; 

template<class T> 
struct X : std::conditional<is_nulltype<T>::value,Null,typename std::conditional<T::one,_1,_2>::type>::type 
{ 
}; 

int _tmain(int argc, _TCHAR* argv[]) 
{ 
X<Null> x;//won't compile no Null::one but I don't need that member in Null at all 
    return 0; 
} 
+1

Eldeki sorun için '' N' '' Null' yazın. –

+0

@Alf, iki "neredeyse" özdeş sınıfa sahip olmam gerektiği anlamına gelir. Gitme. –

+0

Burada aradığınız şeyin "tembel değerlendirme" ve "tembel değerlendirme" değil gibi görünüyor. Null for T'nin X tanımında değiştirilmesi, bir sözdizimi hatasına neden olur. Sözdiziminin değerlendirilmesi geciktirilemez. – goedson

cevap

9

bunun için her zamanki teknik std::conditional iki metafunctions arasında seçim sahip olmaktır.

+0

'false_case', 'koşullu' olarak onu biraz daha kısa yapmak için temel sınıf olarak kullanabilir. – aaz

+0

teşekkürler, bence inandığım şeyi yapacağım. Eğer yapmazsan, sana haber vereceğim. –