begin process at 2010 02 09 20:42:06
  Trouver un code source :
 
dans
 
Accueil > Forum > 

C++ & C++ .NET

 > 

Divers

 > 

Débutant(e)

 > 

Mon fopen ne fonctionne pas


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Mon fopen ne fonctionne pas

dimanche 11 mai 2008 à 08:01:13 | Mon fopen ne fonctionne pas

daviddubois

Bonjour tout le monde,

Mon fopen ne fonctionne pas et je suis bloqué depuis hier soir.

    Fichier = fopen(NomFichier,"rt");
    if (Fichier == NULL) return false;

arrivé sur la ligne if (Fichier==NULL) return false, il renvoie false car Fichier vaut bien NULL alors que je suis sûr que mon fichier se trouve au bon endroit et que le nom est correct.

Je l'appelle via la main :

    if(Produit.Charger("produit.txt"))printf("OK");

voici une partie de mon code :

#include <BasicConsole.h>
#include "CarambouilleDD1.h"

////////////////
// CProduits //
///////////////

CProduit::CProduit()
:m_PP(0) // j'initialise à zéro au cas où le modificateur ne sait pas affecter une valeur.
{
}

//le constructeur par copie est appelé avec le constructeur par copie
CProduit::CProduit(const CProduit& Source)
:CGenerique(Source),m_NomProduit(Source.m_NomProduit),m_PP(Source.m_PP)
{
}

//le constructeur spécifique est appelé avec la méthode d'ajout
CProduit::CProduit(const char* UnNom,int UnPrix)
:m_PP(0) //on recopie la même chose que dans le constructeur spécifique
{
    Nom(UnNom);
    PP(UnPrix);
}

CProduit::~CProduit()
{
}

CGenerique* CProduit::Cloner() const
{
    return new CProduit(*this);
}

bool CProduit::Nom(const char* UnNom)
{
    if((strlen(UnNom)<1)&&(UnNom==NULL))return false;
    return m_NomProduit.Chaine(UnNom);   
}

bool CProduit::PP(int UnPrix)
{
    if(UnPrix < 1) return false;
    m_PP = UnPrix; //on peut ici transformer la valeur d'un membre privé car s'est sa propre classe
    return true;
}

const char* CProduit::Nom() const
{
    return m_NomProduit.Chaine;
}

int CProduit::PP() const
{
    return m_PP;
}

bool CProduit::EstValide() const
{
    return (strlen(Nom())>1 && (PP() > 1));
}

bool CProduit::GereUnicite() const
{
    return true;
}

int CProduit::Comparer(const CGenerique& Autre, long TypeComparaison) const
{
    const CProduit& P = (const CProduit&)Autre;
    switch (TypeComparaison)
    {
    case 0:
        return m_NomProduit.Comparer(P.m_NomProduit,Comparaison_TriCroissantNonStrict);
   
    }
    return 0;
}

long CProduit::NombreClesDeTri() const
{
    return 1;
}

//////////////////
// CTabProduits //
//////////////////

CTabProduits::CTabProduits()
:CTableauGenerique(CProduit())
{
}

CTabProduits::CTabProduits(const CTabProduits& Source)
:CTableauGenerique(Source)
{
}

CTabProduits::~CTabProduits()
{
}

CGenerique* CTabProduits::Cloner() const
{
    return new CTabProduits(*this);
}

CProduit& CTabProduits::Element(long Indice) const
{
    return (CProduit&)CTableauGenerique::Element(Indice);
}

long CTabProduits::Indice(const char* UnNom) const
{
    return CTableauGenerique::Indice(CProduit(UnNom,1));
}

bool CTabProduits::Charger(const char* NomFichier)
{
    CChargeurFichierTexte    Chargeur;

    return Chargeur.Charger(NomFichier,'\t',FctnTraiterLigne,this);
}

bool CTabProduits::FctnTraiterLigne(const CChargeurFichierTexte& Chargeur, void* Contexte)
{
    return ((CTabProduits*)Contexte)->TraiterLigne(Chargeur);
}

bool CTabProduits::TraiterLigne(const CChargeurFichierTexte& Chargeur)
{
    if (Chargeur.NombreChamps() == 2) Ajouter(CProduit(Chargeur.Champs(0),atol(Chargeur.Champs(1))));
    return true;
}

bool CTabProduits::Ajouter(const CProduit& Modele)
{
    return CTableauGenerique::Ajouter(Modele);
}

et le fichier .h

#ifndef CARAMBOUILLE_H
#define CARAMBOUILLE_H

#include "chaine.h"
#include "generique.h"

class CProduit;
class CTabProduits;

class CProduit : public CGenerique
{
public:
    CProduit();
    CProduit(const CProduit& Source);
    CProduit(const char* UnNom, int UnPrix);
    ~CProduit();

    CGenerique*    Cloner() const;
    const char*    Nom() const;
    int            PP() const;
    bool        Nom(const char* UnNom);
    bool        PP(int UnPrix);
    bool        EstValide() const;
    bool        GereUnicite() const;
    long        NombreClesDeTri() const;
    int            Comparer(const CGenerique& Autre, long TypeComparaison) const;



private :
    CChaine        m_NomProduit;
    int            m_PP; //Prix Produit
};

class CTabProduits : public CTableauGenerique
{
public:
    CTabProduits();
    CTabProduits(const CTabProduits& Source);
    ~CTabProduits();
   
    CGenerique*        Cloner() const;
    CProduit&        Element(long Indice) const;
    long            Indice(const char* UnNom) const;
    bool            Charger(const char* NomFichier);
    bool            Ajouter(const CProduit& Modele);

private:
    static bool    FctnTraiterLigne(const CChargeurFichierTexte& Chargeur, void* Contexte);
    bool        TraiterLigne(const CChargeurFichierTexte& Chargeur);


};
#endif

et le .cpp pour le chargement :

#include <BasicConsole.h>
#include "CarambouilleDD1.h"

////////////////
// CProduits //
///////////////

CProduit::CProduit()
:m_PP(0) // j'initialise à zéro au cas où le modificateur ne sait pas affecter une valeur.
{
}

//le constructeur par copie est appelé avec le constructeur par copie
CProduit::CProduit(const CProduit& Source)
:CGenerique(Source),m_NomProduit(Source.m_NomProduit),m_PP(Source.m_PP)
{
}

//le constructeur spécifique est appelé avec la méthode d'ajout
CProduit::CProduit(const char* UnNom,int UnPrix)
:m_PP(0) //on recopie la même chose que dans le constructeur spécifique
{
    Nom(UnNom);
    PP(UnPrix);
}

CProduit::~CProduit()
{
}

CGenerique* CProduit::Cloner() const
{
    return new CProduit(*this);
}

bool CProduit::Nom(const char* UnNom)
{
    if((strlen(UnNom)<1)&&(UnNom==NULL))return false;
    return m_NomProduit.Chaine(UnNom);   
}

bool CProduit::PP(int UnPrix)
{
    if(UnPrix < 1) return false;
    m_PP = UnPrix; //on peut ici transformer la valeur d'un membre privé car s'est sa propre classe
    return true;
}

const char* CProduit::Nom() const
{
    return m_NomProduit.Chaine;
}

int CProduit::PP() const
{
    return m_PP;
}

bool CProduit::EstValide() const
{
    return (strlen(Nom())>1 && (PP() > 1));
}

bool CProduit::GereUnicite() const
{
    return true;
}

int CProduit::Comparer(const CGenerique& Autre, long TypeComparaison) const
{
    const CProduit& P = (const CProduit&)Autre;
    switch (TypeComparaison)
    {
    case 0:
        return m_NomProduit.Comparer(P.m_NomProduit,Comparaison_TriCroissantNonStrict);
   
    }
    return 0;
}

long CProduit::NombreClesDeTri() const
{
    return 1;
}

//////////////////
// CTabProduits //
//////////////////

CTabProduits::CTabProduits()
:CTableauGenerique(CProduit())
{
}

CTabProduits::CTabProduits(const CTabProduits& Source)
:CTableauGenerique(Source)
{
}

CTabProduits::~CTabProduits()
{
}

CGenerique* CTabProduits::Cloner() const
{
    return new CTabProduits(*this);
}

CProduit& CTabProduits::Element(long Indice) const
{
    return (CProduit&)CTableauGenerique::Element(Indice);
}

long CTabProduits::Indice(const char* UnNom) const
{
    return CTableauGenerique::Indice(CProduit(UnNom,1));
}

bool CTabProduits::Charger(const char* NomFichier)
{
    CChargeurFichierTexte    Chargeur;

    return Chargeur.Charger(NomFichier,'\t',FctnTraiterLigne,this);
}

bool CTabProduits::FctnTraiterLigne(const CChargeurFichierTexte& Chargeur, void* Contexte)
{
    return ((CTabProduits*)Contexte)->TraiterLigne(Chargeur);
}

bool CTabProduits::TraiterLigne(const CChargeurFichierTexte& Chargeur)
{
    if (Chargeur.NombreChamps() == 2) Ajouter(CProduit(Chargeur.Champs(0),atol(Chargeur.Champs(1))));
    return true;
}

bool CTabProduits::Ajouter(const CProduit& Modele)
{
    return CTableauGenerique::Ajouter(Modele);
}

Merci d'avance pour votre aide.

dimanche 11 mai 2008 à 10:59:08 | Re : Mon fopen ne fonctionne pas

jfrancois

Bonjour,

1) Les 2 instructions suivantes sont tout à fait correctes donc le problème est certainement au niveau du fichier ! Il faudrait initialiser avec un nom complet pour tester : "C:\\Temp\\Fichier.txt" (par ex.).

Fichier = fopen(NomFichier,"rt");
if (Fichier == NULL) return false;

2) strlen(UnNom) avec UnNom = NULL ça plante !

bool CProduit::Nom(const char* UnNom)
{
   if((strlen(UnNom)<1)&&(UnNom==NULL))return false;
   return m_NomProduit.Chaine(UnNom);   
}

Il vaudrait mieux mettre (si pointeur nul ou si longueur nulle)
:

   if (UnNom == NULL  ||  *UnNom == 0) return false;


Jean-François

dimanche 11 mai 2008 à 11:03:34 | Re : Mon fopen ne fonctionne pas

daviddubois

Bonjour Jean-François,

Un tout grand merci pour ta réponse.

Je viens juste de trouver le problème !

J'avais juste oublié de mettre ( ) dans :

const char* CProduit::Nom() const
{
    return m_NomProduit.Chaine;
}


Maintenant ça fonctionne.

Merci encore.




Cette discussion est classée dans : const, return, bool, cproduit, ctabproduits


Répondre à ce message

Sujets en rapport avec ce message

Fonction à nbr d'arguments variable [ par Xilofeon ] Bonjour.   Alors gros problème.J'utilise des fonctions à nombres variables d'arguments. Alors je vais vous montré le code est expliqué aprés car je vo Probleme de WNDPROC [ par threadom ] Explication Voila j'essaye tout simplement de me faire une classe pour Impossible de créer un objet [ par daviddubois ] Bonjour tout le monde,Je débute en C++.Je suis occupé à créer un programme qui va me permettre de calculer le rayon d'un triangle, la superficie d'un qu'en pensez vous?? besoin d'aide!! lol [ par nelly77 ] bonjour je voudrai créer un tableau avec une liste de produits ayant des attributs comme  leur nom, leur etat dans un stock, la duree de fabrication e Concaténation de deux chaines de caractères par surchage d'opérateur [ par laurentdav ] Je n'arrive pas à surcharger l'opérateur + afin de concaténer deux chaîne de caractères au sein d'une classe. Il est à noter que je ne veux pas utilis conversion c++ vers c# [ par survcopt ] Bonjour,Je cherche à convertir le code d'une dll dont j'ai le source qui est écrit en c++ vers une version en c# car je maîtrise mieux ce langage.Je c strlen to const char* [ par thefrox ] Bonjour,je cherche a convertir la fonction C++ strlen pour strcatex :  strcat( buffer , strlen ( buffer ) );Le strlen(char*s VC++ 6 /recompilé sur VC++ 2005 [ par lui88 ] Bonjour , j'essai de recompilé mon programme sur VC++ 2005 , mais plein d'erreur s'affiche :s. j'en est reglé une grande partie mais là je n'y arrive Initialisation d'un attribut static const [ par lolo38550 ] Bonjour à tous, J'aimerai pouvoir disposer d'un attribut (protected) _nomClasse qui contiendrait le nom de la classe. Ce nom doit être le même pour t const copie c++ [ par amoulina ] Salut tout le monde svp est ce qu'ilya quelqun qui peut m'aider à corriger une erreur que me signale le viuel c++ conçernant le const de copie. Matric


Nos sponsors


Sondage...

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,530 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales