2016_2017:s3:concprogobjet:td:td3
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
2016_2017:s3:concprogobjet:td:td3 [2016/10/22 18:38] – [Question 5 : Extension un peu moins facile] blay | 2016_2017:s3:concprogobjet:td:td3 [2016/11/08 17:54] (current) – [RETOUR SUR LES RENDUS] blay | ||
---|---|---|---|
Line 42: | Line 42: | ||
==== Question 5 : Extension un peu moins facile ==== | ==== Question 5 : Extension un peu moins facile ==== | ||
- | Les ingénieurs de l' | + | Les ingénieurs de l' |
Un engin est défini par une interface comme suit : | Un engin est défini par une interface comme suit : | ||
- | Interface Engin { int getWeight(); | + | Interface Engin { int getWeight(); |
On considère que tous les véhicules dans notre entreprise ont la même puissance. | On considère que tous les véhicules dans notre entreprise ont la même puissance. | ||
On veut pouvoir savoir la consommation totale d'un convoi allant à sa vitesse maximale (c' | On veut pouvoir savoir la consommation totale d'un convoi allant à sa vitesse maximale (c' | ||
+ | |||
+ | |||
+ | ==== Questions | ||
+ | |||
+ | Que feriez-vous si l'on vous disait que l'on veut pouvoir créer das véhicules à partir de leur poids à vide, charge maximale, etc... ? | ||
==== RENDU ==== | ==== RENDU ==== | ||
Line 55: | Line 60: | ||
A la fin du TD, en l' | A la fin du TD, en l' | ||
- | Dépôt sur jalon avec comme nom : GroupeNumero - Noms des etudiants | + | Dépôt sur [[http://jalon.unice.fr/ |
+ | ==== RETOUR SUR LES RENDUS ==== | ||
+ | ON évite ou on ne fait pas : | ||
+ | * la duplication de code par exemple des setCharge | ||
+ | * nom de variable d' | ||
+ | * Définir une classe abstraite et implementer toutes ses méthodes de manière absurde : on ne sait même pas ce qui doit être redéfini (eg. vitesseMax à 0)! | ||
+ | * Des tests sous forme de toString | ||
+ | * aVOIR UNE CHARGE MAX ET NE PAS EN TENIR COMPTE en chargeant le véhicule | ||
+ | * passer la charge à un vehicule qui a déjà une charge ! | ||
+ | * recopier les un sur les autres des codes pas très malins ou qui datent d'une vieille version de java | ||
+ | * prévoir une méthode d' | ||
+ | * Pas de S à la fin du nom d'une classe comme Vehicule. | ||
+ | * ne pas savoir calculer le min d'un ensemble et ne pas faire de tests! | ||
+ | * BANIR LES toString dans vos assert.. imaginez le coût d'une modification d'un toString !! et que testez-vous vraiment? | ||
+ | * Ne mettez pas un attribut quand vous pouvez mettre une association ! Mettez les cardinalités ! | ||
+ | * N' | ||
+ | * aTTENTION AU CHOIX ARBITRAIRE D4UNE valeur max comme 150... si demain vous gérez des convois de ferrari, vous devrez aller modifier votre code de convoi !! Integer.MAX_VALUE résoud votre problème par exemple. | ||
+ | * cOMMENT FAIRE POur qu'un véhicule soit un engin???? Il faut répondre à cette question en TD. | ||
+ | * Mettez le toString en facteur surtout quand vous le recopiez partout! | ||
+ | * Prévoir en dure le calcul de la vitesse max et autoriser la modification de la charge !! | ||
+ | * Ne définissez pas toutes vos variables en public ou même protected, simplement parce que vous ne savez pas utiliser des cascades de constructeurs ou des accesseurs! Et réfléchissez à la cohérence de votre code même sur un exemple aussi simple ! | ||
+ | * Sur PAPIER, POUR NOTER QU'UNE CLASSE EST abstraite, vous pouvez simplement écrire < | ||
+ | * HORREUR!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! (piste : Polymorphisme ce n'est pas une maladie contagieuse.) | ||
+ | <code java> | ||
+ | public double getVitesseMax(){ | ||
+ | double resultat =150; | ||
+ | double resultat2 =0; | ||
+ | for (Vehicule v : listeVehicule) { | ||
+ | if(v instanceof PetitBus){ | ||
+ | resultat2=((PetitBus) v).getVitesseMax(); | ||
+ | } | ||
+ | if(v instanceof CamionCiterne){ | ||
+ | resultat2=((CamionCiterne) v).getVitesseMax(); | ||
+ | } | ||
+ | if(v instanceof CamionBache){ | ||
+ | resultat2=((CamionBache) v).getVitesseMax(); | ||
+ | } | ||
+ | if(v instanceof VoitureSansPermis){ | ||
+ | resultat2=((VoitureSansPermis) v).getVitesseMax(); | ||
+ | } | ||
+ | if (resultat2< | ||
+ | resultat = resultat2; | ||
+ | } | ||
+ | } | ||
+ | return resultat; | ||
+ | } | ||
+ | </ |
2016_2017/s3/concprogobjet/td/td3.1477161523.txt.gz · Last modified: 2016/10/22 18:38 by blay