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

Langage Java Discussion :

Traitement pas effectué après la boucle


Sujet :

Langage Java

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut Traitement pas effectué après la boucle
    Salut à tous,
    j'ai besoin de votre aide dans le problème suivant:
    je suis entrain de faire une comparaison entre deux documents XML afin de compter les éléments communs à chaque niveau (cn1 et cn2).
    Voici le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     
    static void comparaison( ArrayList<Obj> tab1,ArrayList<Obj>tab2) 
    {
     try{
           int niv1 =niv(tab1);  int niv2=niv(tab2);  int i=0; int j=0;
           int cn1[]=new int[niv1];  int cn2[]=new int[niv2];
           while(i<tab1.size()&j<tab2.size()){
           if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())==0)
           {
             System.out.println("oui");
             cn1[((Obj) tab1.get(i)).getniv()]=cn1[((Obj) tab1.get(i)).getniv()]+1;
             cn2[((Obj) tab2.get(j)).getniv()]=cn2[((Obj) tab2.get(j)).getniv()]+1;
     
            i++; j++;
           }
         if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())<0)
          {
            i++;
          }
         else{
    	   j++;
             }
    }
     
    /***traitement**/	  
      par exemple System.out.println("hhh");
     }catch(Exception e){}
     
    }
    Mon problème est que quand j’exécute le programme, il affiche seulement les messages de la boucle mais ne fait pas le traitement après la boucle, même si le traitement est un simple affichage. Je ne sais pas où le problème!!

    Merci d'avance.

  2. #2
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 117
    Points : 219
    Points
    219
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     while(i<tab1.size()&j<tab2.size()){
    Cette ligne ne devrais pas plutôt contenir un double && ?

    Sinon essaye de te relire un peu, bien que je soit mauvais en orthographe, ça pique vraiment les yeux...

    Mon petit blog sans prétention : http://blog.octera.info/

  3. #3
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    On n'ignore pas les exceptions, on les traite ou on les laisse remonter!!

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2007
    Messages : 211
    Points : 137
    Points
    137
    Par défaut
    Ca sent la boulcle infini.
    Tu dois ne pas sortir de ta boucle.
    essais d'afficher dans la boucle: tab1.size(), tab2.size(), j et i...
    Pour être sur que i ou j devient bien plus grand que les size() de tes tab même si vu le programme j'ai du mal a voir comme ca ne serait pas le cas ...

    ou alors comme le pense tchize_ tu as une exception. Pour verifier ca met un println dans l'exception ...

    ou alors comme le pense OcterA c'est peut être la condition du while qui rate à cause du &&.

  5. #5
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    Salut à tous,
    et merci pour me répondre.
    oui c'est un problème de "Exception" mais je ne sais pas comment le résoudre
    voici l'exception:
    java.lang.IndexOutOfBoundsException: Index: 3, Size: 3
    J'attends vos réponse et merci d'avance.

  6. #6
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Points : 13 670
    Points
    13 670
    Par défaut
    Citation Envoyé par loudji Voir le message
    oui c'est un problème de "Exception" mais je ne sais pas comment le résoudre
    Ce n'est pas la façon de le dire. "Exception" est l'exception parente de toute exception. "NullPointerException" ou "IndexOutOfBoundsException" sont des sous-types d'exception.

    Ainsi l'exemple ci-dessous effectue un traitement particulier pour toutes erreurs :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    try {
      // Ton code
    catch (Exception e) {
      // Ton traitement en cas d'erreurs
    }
    Alors que cet exemple effectue un traitement particulier pour un type d'erreur particulier :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    try {
      // Ton code
    } catch (NumberFormatException e) {
      // Ton traitement en cas d'erreurs de format de nombre
    }

    Ton erreur indique que tu accède à un élément qui n'existe pas dans ton tableau (car ton tableau est plus petit que l'indice que tu recherches). En étouffant pas l'exception c'est donc bien plus parlant.
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  7. #7
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 117
    Points : 219
    Points
    219
    Par défaut
    As tu corriger le problème que je t'ai montrer dans mon premier post?
    Peut tu remettre le code que tu a modifié?

    Mon petit blog sans prétention : http://blog.octera.info/

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    281
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 281
    Points : 321
    Points
    321
    Par défaut
    Je suis sur que c'est le problème décris dans la première réponse. Comme cette condition semble toujours vrai avec "&" tu ne sors jamais de ta boucle. Utilise un "&&" entre tes deux conditions.

  9. #9
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    salut à tous,
    oui j'ai changer et j'ai met "&&".
    mais le problème est reste.

  10. #10
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    voici le code modifie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     
    static void comparaison( ArrayList<Obj> tab1,ArrayList<Obj>tab2) 
    {
     try{
           int niv1 =niv(tab1);  int niv2=niv(tab2);  int i=0; int j=0;
           int cn1[]=new int[niv1];  int cn2[]=new int[niv2];
           while(i<tab1.size()&&j<tab2.size()){
           if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())==0)
           {
             System.out.println("oui");
             cn1[((Obj) tab1.get(i)).getniv()]=cn1[((Obj) tab1.get(i)).getniv()]+1;
             cn2[((Obj) tab2.get(j)).getniv()]=cn2[((Obj) tab2.get(j)).getniv()]+1;
     
            i++; j++;
           }
         if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())<0)
          {
            i++;
          }
         if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())>0)
    	   j++;
             }
    }
     
    /***traitement**/	  
      par exemple System.out.println("hhh");
     }catch(Exception e){{e.printStackTrace();}
     
    }

  11. #11
    Membre actif Avatar de fastdeath124
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Août 2011
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Ingénieur sécurité

    Informations forums :
    Inscription : Août 2011
    Messages : 117
    Points : 200
    Points
    200
    Par défaut
    Il y a un problème dans l'algorithme. Au cours de la dernière itération de la boucle, tout fonctionne bien normalement jusqu'à la ligne 15.
    En arrivant à la ligne 16:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())<0)
    La valeur de i (étant incrémentée) dépasse l'indice maximale de tab1, donc lance OutOfBoundsException.
    Le même problème existe à la ligne 20

    Il faut donc tester si i dépasse l'indice maximale avant d'appeler la méthode "get". Pour écrire proprement, il est toujours préférable de tester si un élément existe avant de l'utiliser.

  12. #12
    Modérateur
    Avatar de wax78
    Homme Profil pro
    Chef programmeur
    Inscrit en
    Août 2006
    Messages
    4 075
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 4 075
    Points : 7 980
    Points
    7 980
    Par défaut
    Citation Envoyé par fastdeath124 Voir le message
    Il faut donc tester si i dépasse l'indice maximale avant d'appeler la méthode "get". Pour écrire proprement, il est toujours préférable de tester si un élément existe avant de l'utiliser.
    Oui certes... Mais en théorie il ne faudrait pas à avoir à tester cela.
    C'est encore en amont qu'il faut régler ce genre de problème.

    Un peu comme faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for (int i = 0; i < 8; i++)
    {
    if (i<tableau.size())
    System.err.println(""+tableau.get(i));
    }
    Au lieu de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for (int i = 0; i < tableau.size(); i++)
    		{
    			System.err.println(""+tableau.get(i));
    		}
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  13. #13
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    Salut à tous,
    Exactement monsieur fastdeath124, votre analyse est juste.
    Mais comment je sortirai de ce problème?

  14. #14
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Points : 13 670
    Points
    13 670
    Par défaut
    Citation Envoyé par loudji Voir le message
    Exactement monsieur fastdeath124 le problème est dans cette ligne.
    mais comment je sortirai de ce problème?
    En faisant un peu attention aux indices de tableau que tu utilises. Trace les valeurs et tu verras que tu utilises des indices trop haut.
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  15. #15
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    je pense que la solution est d'utiliser "if ..else" .

  16. #16
    Modérateur
    Avatar de wax78
    Homme Profil pro
    Chef programmeur
    Inscrit en
    Août 2006
    Messages
    4 075
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 4 075
    Points : 7 980
    Points
    7 980
    Par défaut
    Ton problème d'après moi il est ici (je ne fait que repeter ce que fastdeath124 a dit plus haut) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())<0)
    {
       i++;
    }
    if(((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())>0)
    {
       j++;
    }
     
    ...
    éventuellement tu incrémentes i (si la conditon est validée).
    Ensuite tu refait un get(i) qui peux provoquer le IndexOutOfbounds.

    Donc tu dois changer ton test :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    int ret = ((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom());
    if(ret<0)i++;
    if(ret>0)j++;
    (ce que tu entendais peut être par if...else)
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  17. #17
    Membre actif Avatar de fastdeath124
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Août 2011
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Ingénieur sécurité

    Informations forums :
    Inscription : Août 2011
    Messages : 117
    Points : 200
    Points
    200
    Par défaut
    Absolument wax78, je pense que le bout de code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ((Obj)tab1.get(i)).getNom().compareTo(((Obj)tab2.get(j)).getNom())
    est une succession d'appels relativement lourde et ça serait dommage de la répéter trois fois pour faire le même test.
    Ce que je rajoute pour améliorer ta solution, c'est des "else" ou encore mieux un switch/case (puisqu'il s'agit toujours d'un test sur le signe de "ret").

  18. #18
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2012
    Messages : 88
    Points : 51
    Points
    51
    Par défaut
    Salut à tous,
    et merci à tous pour vos réponses et vos collaborations.
    Exactement monsieur wax78 vous avez raison. J'ai essayé "if.. else" elle marche bien pour le moment. et même ta solution elle est très bonne.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 10
    Dernier message: 17/03/2011, 16h00
  2. Gif qui ne veut pas disparaitre après traitement
    Par GreatDeveloperOnizuka dans le forum C#
    Réponses: 6
    Dernier message: 31/07/2009, 10h43
  3. Boucle si - alors qui n'est pas effectué
    Par tomato178837 dans le forum Langage
    Réponses: 5
    Dernier message: 09/05/2008, 13h08
  4. Réponses: 13
    Dernier message: 20/03/2006, 16h26
  5. [MySQL] Traitement des variables d'une boucle for
    Par liryc78 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 06/03/2006, 20h53

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