Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention. Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé. Pour plus d'informations, nous vous invitons à lire les règles générales du forum
Merci de colorer votre code à l'aide du bouton Code
Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: cpp;">Votre code ici</pre>.
Ton code est difficilement lisible, édite ton post et utilise le bouton [</>].
Ton opérateur+ n'est pas si mal, c'est même la fonction la plus exacte de ton code. Ce qui ne va pas est surtout le type de retour. Une addition ça fournit un nouvel objet donc ça retourne un objet pas une référence. Et il faut ôter le static qui servait à corriger le warning qui t'indiquait le vrai problème.
Quant à l'opérateur[]. Que vient faire std::cout ici et cette boucle ? Et il faut retourner le char attendu! Ce qu'il faut écrire c'est une double fonction :
char chaine::operator[](int i) const { // permet la lecture du i-ème caractère
return fat[i];
}
char& chaine::operator[](int i) { // permet l'écriture du i-ème caractère
return fat[i];
}
j'essaie de return par un objet mais un message erreur : [Error] invalid initialization of reference of type 'chaine&' from expression of type 'char'
Alors que je t'avais indiqué :
Dalfab a écrit:
Ton opérateur+ n'est pas si mal, c'est même la fonction la plus exacte de ton code. Ce qui ne va pas c'est surtout le type de retour. Une addition ça fournit un nouvel objet donc ça retourne un objet pas une référence. Et il faut ôter le static qui servait à corriger le warning qui t'indiquait le vrai problème.
Il faut donc tout simplement lever le & dans le type de retour. Que te manque-t-il pour écrire ton opérateur+?
Mais attention comme tes autres fonctions sont foireuses. Par exemple le constructeur par défaut va planter (utilisé ligne 91), le constructeur de copie a des erreurs (utilisé ligne 91). Il y aura des problèmes à l'utilisation de ton opérateur+.
En recherche d'emploi.
operator + dans classe chaine ne fonctionne pas
× Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
× Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
En recherche d'emploi.
Recueil de code C et C++ http://fvirtman.free.fr/recueil/index.html
En recherche d'emploi.