Maison >développement back-end >C++ >Comment stocker des pointeurs de fonction membre dans des objets de fonction de bibliothèque standard ?

Comment stocker des pointeurs de fonction membre dans des objets de fonction de bibliothèque standard ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-22 21:20:11918parcourir

How to Store Member Function Pointers in Standard Library Function Objects?

Pointeurs de fonction vers des fonctions membres avec des fonctions de bibliothèque standard

Dans le but de stocker des pointeurs de fonction vers des fonctions membres d'une classe dans une carte contenant objets de fonction de bibliothèque standard, une erreur courante se produit. Comme démontré dans le code ci-dessous, l'attribution d'une fonction membre directement à un objet fonction entraîne une erreur :

#include <functional>

class Foo {
public:
    void doSomething() {}
    void bindFunction() {
        // ERROR
        std::function<void(void)> f = &Foo::doSomething;
    }
};

L'erreur rencontrée est due à l'exigence implicite d'une fonction membre pour un objet. Une fonction membre est toujours appelée avec un objet, en passant effectivement le pointeur "this" comme premier argument.

Pour résoudre ce problème, la signature de la fonction doit spécifier que la fonction ne prend aucun argument (< vide(vide)>). De plus, le premier (et unique) argument doit être lié. Ceci peut être réalisé en utilisant std::bind():

std::function<void(void)> f = std::bind(&Foo::doSomething, this);

Si la fonction nécessite des paramètres, des espaces réservés peuvent être utilisés :

using namespace std::placeholders;
std::function<void(int, int)> f = std::bind(&Foo::doSomethingArgs, this, std::placeholders::_1, std::placeholders::_2);

Les lambdas C 11 peuvent également être utilisés :

std::function<void(int, int)> f = [=](int a, int b) {
    this->doSomethingArgs(a, b);
};

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn