Maison >développement back-end >C++ >Erreur de compilation C++ : les objets non const ne peuvent pas appeler les fonctions membres const, comment la résoudre ?

Erreur de compilation C++ : les objets non const ne peuvent pas appeler les fonctions membres const, comment la résoudre ?

WBOY
WBOYoriginal
2023-08-22 15:48:221727parcourir

Erreur de compilation C++ : les objets non const ne peuvent pas appeler les fonctions membres const, comment la résoudre ?

C++ est un langage de programmation largement utilisé, mais divers problèmes sont souvent rencontrés lors du processus de codage. L'un de ces problèmes est l'erreur de compilation : "Les fonctions membres Const ne peuvent pas être appelées sur des objets non const". Lorsque ce problème se produit, le compilateur vous le demandera, ce qui signifie que lorsque la fonction const est appelée, l'objet est traité comme « non-const », ce qui peut conduire à un comportement imprévisible. Cet article explique ce problème et comment le résoudre.

  1. Objets non const et fonctions membres const

En C++, vous pouvez ajouter le mot-clé const après la fonction membre pour la définir comme fonction membre const, ce qui signifie qu'elle ne modifiera pas l'état de l'objet. Par exemple :

class MyClass {
public:
    void changeValue() { m_value = 1; }
    int getValue() const { return m_value; }
private:
    int m_value;
};

Dans le code ci-dessus, la fonction changeValue() n'est pas une fonction const, mais la fonction getValue() est une fonction const, elle ne change pas l'état de l'objet et elle a été marquée comme const .

  1. Cause du problème

En C++, les appels entre des objets non const et des fonctions membres const peuvent être implémentés, mais lorsqu'un objet non const appelle une fonction membre const, le compilateur génère une erreur de compilation. La raison en est que les fonctions membres const garantissent que l'état de l'objet n'est pas modifié, donc seuls les objets const peuvent les appeler. Par conséquent, les objets non const ne peuvent pas appeler les fonctions membres const, sinon des problèmes surviendront.

  1. Solution

Pour résoudre ce problème, il existe deux méthodes courantes :

3.1 Convertir des objets non const en objets const

L'appel de fonctions membres const sur des objets non const n'est pas autorisé, mais vous pouvez L'objet est déclaré const. De cette façon, lorsque l'objet est dans l'état const, la fonction membre const peut être appelée. Par exemple :

MyClass obj;
const MyClass& constObj = obj;
int value = constObj.getValue();

Dans le code ci-dessus, l'objet non const obj est converti en un objet const constObj, puis la fonction getValue() est appelée. De cette façon, les erreurs du compilateur peuvent être évitées.

3.2 Modifier la fonction membre const en une fonction non const

Si la fonction membre const a vraiment besoin de modifier l'état de l'objet, alors elle doit être modifiée en une fonction non const. Avant de modifier le code d'une fonction membre, assurez-vous de bien comprendre la signification du code et les conséquences de la modification. Si l'objet est uniquement modifié à l'intérieur de la fonction ou si la modification est inutile, il est préférable de conserver la fonction comme fonction const plutôt que de la modifier comme fonction non const.

  1. Résumé

En C++, les appels entre des objets non const et des fonctions membres const sont très courants. Lorsque le compilateur affiche une erreur : « Les objets non const ne peuvent pas appeler les fonctions membres const », vous pouvez utiliser deux solutions courantes : convertir l'objet non const en objet const ou modifier la fonction membre const en fonction non const. Afin d'éviter efficacement ce problème, lors de l'écriture du code, veillez à bien considérer la signification et le rôle de chaque fonction et à choisir le type de fonction correct.

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