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 :

Problème d'affichage avec le méthode toString()


Sujet :

Langage Java

  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Par défaut Problème d'affichage avec le méthode toString()
    Bonjour,

    j'ai écrit différentes classes permettant de gérer un parking.
    Il y a les classes :
    -NumberPlate.java qui permet de gérer les plaques d'imattriculmation des voitures
    -Car.java qui permet de créer les voitures
    -Parking.java qui gère les places.

    Le souci que j'ai, est que lorque j'appelle la méthode toString() de Parking, ça m'affiche null.
    Voici les méthodes de la classe Parking.
    Les autres classes sont joints
    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
    30
    31
    32
    33
    34
    35
    public class Parking {
    private Car [] cars;
    private boolean [] occupe;
     
    public Parking(int nbPlaces){
    	cars = new Car[nbPlaces];
    	for(int i=0; i<nbPlaces; i++)
    		occupe[i] = false;	
    	}
     
    public void park(Car c, int numPlace) throws IllegalStateException{
    		if(occupe[numPlace] != false)
    			throw new IllegalStateException("La place est occupee");
    		cars[numPlace] = c;
    		occupe[numPlace] = true;
    	}
     
    public Car unpark(int numPlace) throws IllegalStateException{
    	if(occupe[numPlace] != true || numPlace > cars.length)
    		throw new IllegalStateException("La place est vide");
    	occupe[numPlace] = false;
    	return cars[numPlace];
    }
     
    @Override public String toString(){
    		StringBuilder sb = new StringBuilder();
    		for(int i=0; i<cars.length; i++){
    			sb.append("Voiture : ").append(cars[i]).append("\n");
    			sb.append("Numero Place : ").append(i).append("\n");
    			sb.append("occupe : ").append(occupe[i]).append("\n");
    			sb.append("\n");
    		}
    		return sb.toString();
    }
    }
    Fichiers attachés Fichiers attachés

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    101
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2006
    Messages : 101
    Par défaut
    ça affiche "null" tout court ?
    pas "Voiture : null" ??

  3. #3
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    A mon avis tu n'entres meme pas dans la boucle (enfin car.length = 0 je pense) pour qu'il t'affiche null ...

  4. #4
    Membre éclairé
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Par défaut
    Citation Envoyé par smallet
    ça affiche "null" tout court ?
    pas "Voiture : null" ??
    Oui. Seulement null

  5. #5
    Membre éclairé
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Par défaut
    Citation Envoyé par in
    A mon avis tu n'entres meme pas dans la boucle (enfin car.length = 0 je pense) pour qu'il t'affiche null ...
    Avant de faire appel à la méthode toString() de Parking, je crée des voitures que j'ajoute à mon parking.
    Le parking n'est pas vide
    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
    public class Main{
    	public static void main(String[] args) {
    		try{
    		Parking p = new Parking(10);
    		NumberPlate a = new NumberPlate("956 XM 94");
    		NumberPlate b = new NumberPlate("959 BM 95");
    		Car c = new Car(a,2000,"Ford",4);
    		Car c1 = new Car(b,3000,"BMW",5);
    		p.park(c, 0);
    		p.park(c1, 1);
    		System.out.println(p);
    		}catch(Exception e){
    			System.out.println(e.getMessage());
    		}
    	}
    }

  6. #6
    Membre émérite Avatar de yann2
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2004
    Messages : 897
    Par défaut
    Bonjour

    Il s'agit d'un NullPointerException. Ton code ne fonctionne pas. Le 'null' affiché correspond à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println(e.getMessage());
    Ajoute un e.printStackTrace(); pour plus d'infos.

    Je pense que ça vient de là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    cars = new Car[nbPlaces];
    	for(int i=0; i<nbPlaces; i++)
    		occupe[i] = false;	
    	}
    occupe n'est jamais créé...

    bon courage

  7. #7
    Membre éclairé
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Par défaut
    Citation Envoyé par yann2
    Bonjour

    Il s'agit d'un NullPointerException. Ton code ne fonctionne pas. Le 'null' affiché correspond à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println(e.getMessage());
    Ajoute un e.printStackTrace(); pour plus d'infos.

    Je pense que ça vient de là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    cars = new Car[nbPlaces];
    	for(int i=0; i<nbPlaces; i++)
    		occupe[i] = false;	
    	}
    occupe n'est jamais créé...

    bon courage
    Ca venait bien de la.
    Merci

  8. #8
    Membre éclairé
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Par défaut
    Comment fait-on pour dire qu'on a plusieurs exceptions différentes.
    J'ai une exception IllegalStateException, Exception

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 120
    Par défaut
    Bonjour,

    il suffit de le catcher indépendemment, en mettant exception en dernier.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    try
     {
       ....
     }
     catch (IllegalStateException ie) {
     
     }
     ... 
     // catch par défaut
     catch (Exception e) {
     
     }

Discussions similaires

  1. [Débutant] [POO]Problème de polymorphisme avec la méthode ToString()
    Par vmolines dans le forum C#
    Réponses: 5
    Dernier message: 08/02/2012, 00h19
  2. Réponses: 2
    Dernier message: 01/08/2008, 12h56
  3. problème d'affichage avec printf
    Par sorari dans le forum C++
    Réponses: 12
    Dernier message: 08/03/2005, 18h30
  4. Réponses: 6
    Dernier message: 19/10/2004, 13h46
  5. Problème d'affichage avec trace
    Par WriteLN dans le forum Flash
    Réponses: 10
    Dernier message: 22/10/2003, 16h59

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