Partage
  • Partager sur Facebook
  • Partager sur Twitter

mon programme n'effectue pas les fonctions

le compilateur ne m'indique pas d'erreur .

    25 avril 2023 à 14:04:13

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    
    
    
    
    typedef struct cartes{
        char numero[20];
        char code[4];
    
    }cartes;
    
    typedef struct transactions{
    
        char auteur[50];
        char destinataire[50];
        double montant;
    
    }transactions;
    
    
    typedef struct Compte{
        char nom[50];
        char numero[20];
        double solde;
        cartes *carte;
        int nbTransactions;
        transactions ens_transactions[20];
    
    }compte;
    
    void creer_compte(char name[50],char numero[20],double solde){
        printf("début de la creation");
        compte nouveauCompte;
        strcpy(nouveauCompte.nom,name);
        strcpy(nouveauCompte.numero,numero);
        nouveauCompte.solde = solde;
    
        FILE *fichier = fopen("bdd_comptes.bd","wb+");
        fwrite(&nouveauCompte,sizeof(compte),1,fichier);
        fclose(fichier);
        printf("comptre enregistre");
    
    }
    
    void chercher_compte(char *nom){
        printf("lancement de la recherche");
        compte compteRecherche;
        int trouve = 0;
        FILE *fichier = fopen("bdd_comptes.bd","rb+");
        fseek(fichier,0,SEEK_SET);
        while ((feof(fichier)==0)){
            fread(&compteRecherche,sizeof(compte),1,fichier);
            if (compteRecherche.nom == nom){
                trouve = 1;
                printf("c'est trouve");
                printf("%s  %s %f", compteRecherche.nom,compteRecherche.numero,compteRecherche.solde);
            } 
            fseek(fichier,1,SEEK_CUR);
    
    
    
        }
        fclose(fichier);
        if (trouve == 0){
            printf("il n'y a aucun compte sous ce nom \n");
            
        }
        
    
    }
    
    
    
    
    int check_solde(compte compteCheck,double montant){
    
        if(compteCheck.solde>=montant){
            return 1;
        }else{
            return 0;
        }
    }
    
    /// @brief 
    /// @param auteur 
    /// @param destinataire 
    /// @param montant 
    void effectuer_transaction(compte *auteurs,compte *destinataire,double montant){
            transactions transaction;
            strcpy(transaction.auteur,(*auteurs).nom);
            strcpy(transaction.destinataire,(*destinataire).nom);
            transaction.montant = montant;
            (*auteurs).solde -= montant;
            (*destinataire).solde += montant;
            (*auteurs).ens_transactions[(*auteurs).nbTransactions] = transaction;
            (*destinataire).ens_transactions[(*destinataire).nbTransactions] = transaction;
            auteurs->nbTransactions += 1;
            destinataire->nbTransactions +=1;
    }
    
     
    int main(){
    
        printf("bonjour\n");
        creer_compte("yann","00000000000000000000",2000);
        printf("étape2");
        creer_compte("marc","01456489453347",5000);
        chercher_compte("marc");
    }


    Bonjour , je suis en licence informatique et je suis en train d'effectuer un projet de banque en ligne programmé en C .

    le problème est que il ne m'affiche que bonjour ce qui veut dire que il y a un problème au niveau de créer compte . mais le terminal ne me retourne aucun probleme et je ne vois pas l'erreur non plus . quelqu'un pourrait m'aider ?

    -
    Edité par yann971 25 avril 2023 à 16:41:43

    • Partager sur Facebook
    • Partager sur Twitter
      25 avril 2023 à 16:25:30

      Bonjour, Merci d'indiquer un titre de sujet en rapport avec votre problématique. 

      Le message qui suit est une réponse automatique activée par un membre de l'équipe de modération. 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

      Mauvais titre

      Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

      Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

      De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

      Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

      Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

      (titre originel : Besoin d'aide sur un exercice en C)

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter
        25 avril 2023 à 17:25:51

        Il faut y aller par étapes. Avant de faire la recherche, tu aurais du t’apercevoir que chaque enregistrement ajouté à ton fichier écrasait le précédent.

        Pour te débloquer (ligne 55) :

                if (compteRecherche.nom == nom)

        C'est comme cela que tu compares des chaînes de caractère ? 

        • Partager sur Facebook
        • Partager sur Twitter
        ...
          25 avril 2023 à 18:05:48

          >le compilateur ne m'indique pas d'erreur .

          > mais le terminal ne me retourne aucun probleme et je ne vois pas l'erreur non plus . quelqu'un pourrait m'aider ?

          Un grand secret de la programmation : les compilateurs s'occupent des fautes d'orthographe, des point-virgules qui manque, des types incompatibles, mais pour le reste on ne peut jamais compter sur eux pour détecter les erreurs de logique dans les programmes.


          Quelques soucis avec les déclarations, soucis dont les conséquences se feront irrémédiablement sentir plus tard : elles contribuent à la confusion, et à la difficulté de se retrouver dans le programme, en premier pour celui qui est en train de l'écrire. Et qui ne voit pas l'erreur, du coup.

           
          typedef struct cartes{
              char numero[20];
              char code[4];
           
          }cartes;
           
          typedef struct transactions{
           
              char auteur[50];
              char destinataire[50];
              double montant;
           
          }transactions;
           
           
          typedef struct Compte{
              char nom[50];
              char numero[20];
              double solde;
              cartes *carte;
              int nbTransactions;
              transactions ens_transactions[20];
           
          }compte;


          Règles générales

          • il faut faire simple
          • il faut être cohérent
          1. Typographie des noms de types

          En général c'est en minuscules, sauf bizarrement
          struct Compte

           Il n'y a probablement aucune raison.

          2. Singulier Pluriel

          Une structure contenant le numéro et le code d'un carte, ça  représente certainement UNE carte, de même qu'un nom et un prénom c'est pour UN compte.

          Donc ça serait bien que carte (et transaction), ça reste au singulier.

          ̉¶

          Pourquoi c'est important ?  Parce que quand on tape son code, on a autre chose à faire que de perdre son temps à se demander si le type s'appelle truc, trucs, Truc ou Trucs.  La programmation, en C en particulier, demande une grande attention à tous les détails, et ce n'est pas le moment de se rajouter de la charge cognitive pour des bêtises.  Nous n'avons qu'un nombre de neurones limité, donc il faut pas les gaspiller.  D'où l'astuce : fixer une convention simple, et s'y tenir absolument.

          Pendant qu'on y est, à la place de

          (*auteurs).solde -= montant;

          on utilise la notation "flèche"

          auteur->solde -= montant;

          Là aussi, le paramètre désigne UN auteur, donc aucune raison de mettre un pluriel, qui fait penser à tort qu'il y en aurait plusieurs.


          Remarque : avec * et ., ça marche, mais c'est un truc à s'embrouiller. Tout comme

          auteurs[0].solde -= montant;

          qui marche aussi, si on va par là.

          On peut aussi enfoncer des clous avec un tournevis, en tapant assez fort.

          -
          Edité par michelbillaud 25 avril 2023 à 18:25:21

          • Partager sur Facebook
          • Partager sur Twitter
            25 avril 2023 à 18:23:45

            Et un détail, mais qui a son importance. Tu passes une chaine de 20 caractères à créer_compte(), mais tu oublies qu'en C, les chaînes de caractères se terminent par un \0. Il y a donc 21 caractères passés, que tu vas stocker dans une variable prévue pour ne retenir que 19 caractères + le \0. Problèmes à l'horizon....

            -
            Edité par edgarjacobs 25 avril 2023 à 18:26:54

            • Partager sur Facebook
            • Partager sur Twitter

            On écrit "j'ai tort", pas "tord" qui est le verbe "tordre" à la 3ème personne de l'indicatif présent

              25 avril 2023 à 21:03:32

              merci pour vos retours , c'est vrai que le code est en bazar , je vais faire le ménage dans le code et mieux gérer les allocations . le problème des comparaisons entre chaines de caractères a été réglé avec un strcmp() .

              -
              Edité par yann971 25 avril 2023 à 21:05:13

              • Partager sur Facebook
              • Partager sur Twitter

              mon programme n'effectue pas les fonctions

              × 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.
              • Editeur
              • Markdown