web-dev-qa-db-fra.com

Visual Studio 2015 "syntaxe non standard; utilisez '&' pour créer un pointeur sur un membre"

J'essaie de mettre en œuvre ma propre implémentation de liste liée en C++ et je ne peux pas comprendre pourquoi je rencontre cette erreur. Je sais qu'il existe une implémentation STL mais pour des raisons que j'essaye moi-même. Voici le code:

#include <iostream>

template <class T>
class ListElement {
public:
    ListElement(const T &value) : next(NULL), data(value) {}
    ~ListElement() {}

    ListElement *getNext() { return next; }
    const T& value() const { return value; }
    void setNext(ListElement *elem) { next = elem; }
    void setValue(const T& value) { data = value; }

private:
    ListElement* next;
    T data;
};

int main()
{
    ListElement<int> *node = new ListElement<int>(5);
    node->setValue(6);
    std::cout << node->value(); // ERROR
    return 0;
}

Sur la ligne spécifiée, le message d'erreur "syntaxe non standard; utilisez '&' pour créer un pointeur sur membre". Qu'est-ce que ça veut dire?

7
Lawrence Aiello

Vous essayez de renvoyer la fonction membre value, et non la variable membre data. Changement

const T& value() const { return value; }

à

const T& value() const { return data; }
8
songyuanyao

Le problème ici est la combinaison déroutante de modèles, les significations multiples d'un opérateur et une faute de frappe.

Vous avez une méthode renvoyant un const T&, où T est un paramètre de modèle. Vous avez l'intention de renvoyer une référence constante à un objet de type T. Mais à cause d'une faute de frappe, le compilateur pense que vous essayez de faire correspondre cela à une méthode (value) plutôt qu'à un objet de type T (data). Le compilateur pense que vous essayez d'utiliser & en tant qu'opérateur pointeur vers membre, et non en tant qu'opérateur référence à objet. Mais il est assez intelligent que quelque chose ne va pas, et donne donc un avertissement.

0
Raedwald