IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++ Discussion :

Ma méthode ajouter ne fonctionne pas


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Par défaut Ma méthode ajouter ne fonctionne pas
    Bonjour tout le monde,

    J'ai un problème avec une méthode que voici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    bool CTraitementProduits::TraiterLigne_Prix(const CChargeurFichierTexte& Chargeur)
    {
    	long n = 0;
    	if(Chargeur.NombreChamps() == 5) 
     
    		for (n =0; n<Chargeur.NombreChamps();n++)
    		{
    			if(!m_PrixDeVente.Ajouter(CPrixDeVente(atoi(Chargeur.Champs(n))))) return false;
    		}
    	return true;
    J'obtiens ce message d'erreur :

    error C2440: 'type cast' : cannot convert from 'int' to 'class CPrixDeVente'
    Il travaille avec ce constructeur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CPrixDeVente::CPrixDeVente(int UnPrix, int UneQuantite)
    : m_PV(0),m_Quantite(0)
    {
    	setPV(UnPrix);
    	setQuantite(UneQuantite);
    }
    Bon je vois bien que mon constructeur à deux paramètres et que je n'en donne qu'un mais le message d'erreur s'applique au premier objet que j'ai passé.

    En vous remerciant d'avance pour votre aide.

    beegees

  2. #2
    Membre éprouvé
    Inscrit en
    Avril 2008
    Messages
    155
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 155
    Par défaut
    hello,

    vu ton message d'erreur et les infos que tu donne,
    je dirais que tu n'as qu'un seul constructeur possédant un seul paramètre(celui de recopie donc)

    le compilo cherche d'abord s'il y a un constructeur de type:

    comme il ne trouve pas, il cherche a convertir ton int en CPrixDeVente...

    a mon avis, si tu tente:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    int bidon = 0;
    ...
    if(!m_PrixDeVente.Ajouter(CPrixDeVente(bidon,atoi(Chargeur.Champs(n))))) return false;
    ca compilera

  3. #3
    Membre expérimenté
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Par défaut
    Citation Envoyé par loicounet Voir le message
    hello,

    vu ton message d'erreur et les infos que tu donne,
    je dirais que tu n'as qu'un seul constructeur possédant un seul paramètre(celui de recopie donc)

    le compilo cherche d'abord s'il y a un constructeur de type:

    comme il ne trouve pas, il cherche a convertir ton int en CPrixDeVente...

    a mon avis, si tu tente:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    int bidon = 0;
    ...
    if(!m_PrixDeVente.Ajouter(CPrixDeVente(bidon,atoi(Chargeur.Champs(n))))) return false;
    ca compilera
    Hello Loic,

    Un tout grand meric pour ton aide très efficace.

    ça fonctionne mais je t'avoue que je ne comprends pas bien pourquoi.

    S'est parce que mon constructeur prend un entier et un autre entier ?

    Encore un tout grand et sincère merci

    beegees

  4. #4
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Dans ton cas le mieux serait peut être de définir un constructeur prenant un entier en paramètre et un second optionnel:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    CPrixDeVente::CPrixDeVente(int UneQuantite,int UnPrix=0) //ou l'inverse
    : m_PV(0),m_Quantite(0)
    {
    	setPV(UnPrix);
    	setQuantite(UneQuantite);
    }

  5. #5
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    D'ailleurs après relecture ton code gagnerait en simplicité et en efficacité en te contentant d'écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    CPrixDeVente::CPrixDeVente(int UneQuantite,int UnPrix=0) //ou l'inverse
    : m_PV(UneQuantite),m_Quantite(UnPrix)
    {}
    Sauf si tes setters font d'autres traitements que de positionner les valeurs en questions.

  6. #6
    Membre éprouvé
    Inscrit en
    Avril 2008
    Messages
    155
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 155
    Par défaut
    re,

    lorsque tu crée un objet, il faut lui donner 0,1,2,etc arguments pour qu'il puisse savoir quel constructeur utiliser.

    ce qui est important c'est le nombre et le type des arguments passés en paramètres:

    exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Mon_objet(); //appelle le constructeur par defaut car 0 arguments
    Mon_objet(int a); 
    Mon_objet(char b); //ce sont 2 constructeurs differents meme s'il n'y a qu'un seul argument
    Mon_objet( Mon_objet const & obj); //constructeur de clonage
    Mon_objet(int a, int b)
    Mon_objet(char a, int b)
    Mon_objet(Mon object const & val, int a)
    tous ces constructeurs sont différents...tu vois le truc?

  7. #7
    Membre expérimenté
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Par défaut
    Citation Envoyé par loicounet Voir le message
    re,

    lorsque tu crée un objet, il faut lui donner 0,1,2,etc arguments pour qu'il puisse savoir quel constructeur utiliser.

    ce qui est important c'est le nombre et le type des arguments passés en paramètres:

    exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Mon_objet(); //appelle le constructeur par defaut car 0 arguments
    Mon_objet(int a); 
    Mon_objet(char b); //ce sont 2 constructeurs differents meme s'il n'y a qu'un seul argument
    Mon_objet( Mon_objet const & obj); //constructeur de clonage
    Mon_objet(int a, int b)
    Mon_objet(char a, int b)
    Mon_objet(Mon object const & val, int a)
    tous ces constructeurs sont différents...tu vois le truc?
    Citation Envoyé par befalimpertinent Voir le message
    D'ailleurs après relecture ton code gagnerait en simplicité et en efficacité en te contentant d'écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    CPrixDeVente::CPrixDeVente(int UneQuantite,int UnPrix=0) //ou l'inverse
    : m_PV(UneQuantite),m_Quantite(UnPrix)
    {}
    Sauf si tes setters font d'autres traitements que de positionner les valeurs en questions.
    Citation Envoyé par befalimpertinent Voir le message
    Dans ton cas le mieux serait peut être de définir un constructeur prenant un entier en paramètre et un second optionnel:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    CPrixDeVente::CPrixDeVente(int UneQuantite,int UnPrix=0) //ou l'inverse
    : m_PV(0),m_Quantite(0)
    {
    	setPV(UnPrix);
    	setQuantite(UneQuantite);
    }
    Re,

    Un tout grand merci à vous deux, vous êtres vraiment sympa et très efficace (en plus vos explications sont simples).

    Franchement, qu'est-ce que je ferais sans ce forum

    beegees

Discussions similaires

  1. [XL-2003] Méthode Copy ne fonctionne pas
    Par sagitarium dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 30/09/2009, 13h58
  2. Méthode objet ne fonctionne pas (4D 2003)
    Par Jimmy Jazz dans le forum 4D
    Réponses: 7
    Dernier message: 18/09/2009, 14h03
  3. méthode OfType() ne fonctionne pas
    Par maa dans le forum C#
    Réponses: 7
    Dernier message: 21/01/2008, 09h12
  4. TRIGGER (test avant ajout) ne fonctionne pas correctement
    Par marcusien dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/06/2007, 18h02

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo