Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
La classe de modèle décrit un functor qui, lorsqu'elle est appelée, retourne l'opérateur NOT logique de son functor stocké à partir d'un.Vous utilisez spécifiez un objet de fonction en termes de son functor stocké.
template<typename Fun>
ref class unary_negate
{ // wrap operator()
public:
typedef Fun stored_function_type;
typedef typename Fun::argument_type argument_type;
typedef bool result_type;
typedef Microsoft::VisualC::StlClr::UnaryDelegate<
argument_type, result_type>
delegate_type;
unary_negate(Fun% functor);
unary_negate(unary_negate<Fun>% right);
result_type operator()(argument_type left);
operator delegate_type^();
};
Paramètres
- Fun
Le type du functor stocké.
Fonctions membres
Définition de type |
Description |
|---|---|
argument_type |
Le type de l'argument de functor. |
delegate_type |
Le type du délégué générique. |
result_type |
Le type du résultat de functor. |
Membre |
Description |
|---|---|
unary_negate |
Construit le functor. |
Opérateur |
Description |
|---|---|
operator() |
Calcule la fonction souhaitée. |
delegate_type^ |
Effectue un cast du functor à un délégué. |
Notes
La classe de modèle décrit un functor d'un qui stocke un autre functor d'un.Elle définit l'opérateur membre operator() afin que, lorsque l'objet est appelé comme fonction, elle retourne l'opérateur NOT logique du functor stocké appelé avec l'argument.
Vous pouvez également passer l'objet comme argument de fonction dont le type est delegate_type^ et il sera converti en conséquence.
Exemple
// cliext_unary_negate.cpp
// compile with: /clr
#include <cliext/algorithm>
#include <cliext/functional>
#include <cliext/vector>
typedef cliext::vector<int> Myvector;
int main()
{
Myvector c1;
c1.push_back(4);
c1.push_back(0);
Myvector c3(2, 0);
// display initial contents " 4 0"
for each (int elem in c1)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// transform and display
cliext::logical_not<int> not_op;
cliext::transform(c1.begin(), c1.begin() + 2, c3.begin(),
cliext::unary_negate<cliext::logical_not<int> >(not_op));
for each (int elem in c3)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// transform and display with function
cliext::transform(c1.begin(), c1.begin() + 2, c3.begin(),
cliext::not1(not_op));
for each (int elem in c3)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
return (0);
}
Configuration requise
en-tête :<cliext/fonctionnel>
Cliext del'espace de noms :