Operadores <functional>
operator==
Testa se o objeto que pode ser chamado está vazio.
template <class Fty>
bool operator==(const function<Fty>& f, null_ptr_type npc);
template <class Fty>
bool operator==(null_ptr_type npc, const function<Fty>& f);
Parâmetros
Fty
O tipo de função a ser encapsulada.
f
O objeto de função
npc
Um ponteiro nulo.
Comentários
Os operadores usam um argumento que é uma referência a um objeto function
e um argumento que é uma constante de ponteiro nulo. Ambos retornam true somente se o objeto function
estiver vazio.
Exemplo
// std__functional__operator_eq.cpp
// compile with: /EHsc
#include <functional>
#include <iostream>
int neg(int val)
{
return (-val);
}
int main()
{
std::function<int(int)> fn0;
std::cout << std::boolalpha << "empty == "
<< (fn0 == 0) << std::endl;
std::function<int(int)> fn1(neg);
std::cout << std::boolalpha << "empty == "
<< (fn1 == 0) << std::endl;
return (0);
}
empty == true
empty == false
operator!=
Testa se o objeto que pode ser chamado não está vazio.
template <class Fty>
bool operator!=(const function<Fty>& f, null_ptr_type npc);
template <class Fty>
bool operator!=(null_ptr_type npc, const function<Fty>& f);
Parâmetros
Fty
O tipo de função a ser encapsulada.
f
O objeto de função
npc
Um ponteiro nulo.
Comentários
Os operadores usam um argumento que é uma referência a um objeto function
e um argumento que é uma constante de ponteiro nulo. Ambos retornam true somente se o objeto function
não estiver vazio.
Exemplo
// std__functional__operator_ne.cpp
// compile with: /EHsc
#include <functional>
#include <iostream>
int neg(int val)
{
return (-val);
}
int main()
{
std::function<int (int)> fn0;
std::cout << std::boolalpha << "not empty == "
<< (fn0 != 0) << std::endl;
std::function<int (int)> fn1(neg);
std::cout << std::boolalpha << "not empty == "
<< (fn1 != 0) << std::endl;
return (0);
}
not empty == false
not empty == true