Istruzione di __if_exists
__if_exists test dell'istruzione se l'identificatore specificato esiste.Se l'identificatore è presente, il blocco di istruzioni specificato verrà eseguito.
__if_exists ( identifier ) {
statements
};
Parametri
Parametro |
Descrizione |
---|---|
identifier |
L'esistenza che per l'identificatore di cui si desidera testare. |
statements |
Una o più istruzioni da eseguire se identifieresiste. |
Note
Attenzione |
---|
Per ottenere risultati più affidabili, utilizzare __if_exists l'istruzione con vincoli seguenti. |
applicare __if_exists istruzione solo ai tipi semplici, non modelli.
applicare __if_exists istruzione agli identificatori sia interni o alla classe esterna.non applicare __if_exists istruzione alle variabili locali.
utilizzare __if_exists istruzione solo nel corpo di una funzione.All'esterno del corpo di una funzione, __if_exists l'istruzione può verificare solo i tipi completamente definiti.
Quando si testano per le funzioni in overload, non è possibile provare un form specifico dell'overload.
Il complemento a __if_exists l'istruzione è __if_not_exists istruzione.
Esempio
Si noti che in questo esempio vengono utilizzati i modelli, che non è consigliato.
// the__if_exists_statement.cpp
// compile with: /EHsc
#include <iostream>
template<typename T>
class X : public T {
public:
void Dump() {
std::cout << "In X<T>::Dump()" << std::endl;
__if_exists(T::Dump) {
T::Dump();
}
__if_not_exists(T::Dump) {
std::cout << "T::Dump does not exist" << std::endl;
}
}
};
class A {
public:
void Dump() {
std::cout << "In A::Dump()" << std::endl;
}
};
class B {};
bool g_bFlag = true;
class C {
public:
void f(int);
void f(double);
};
int main() {
X<A> x1;
X<B> x2;
x1.Dump();
x2.Dump();
__if_exists(::g_bFlag) {
std::cout << "g_bFlag = " << g_bFlag << std::endl;
}
__if_exists(C::f) {
std::cout << "C::f exists" << std::endl;
}
return 0;
}
Output
In X<T>::Dump()
In A::Dump()
In X<T>::Dump()
T::Dump does not exist
g_bFlag = 1
C::f exists