Epreuve de Programmation Orientée Objet 2ème année de Licence Informatique

Dimension: px
Commencer à balayer dès la page:

Download "Epreuve de Programmation Orientée Objet 2ème année de Licence Informatique"

Transcription

1 Epreuve de Programmation Orientée Objet 2ème année de Licence Informatique 1er juin 2007 Durée : 3 heures. Seule la documentation des classes java.util.list et java.util.arraylist distribuée est autorisée. Ce qui est évalué : Votre capacité à : utiliser correctement le langage JAVA pour implémenter une classe ; effectuer des choix corrects pour la visibilité des champs et des méthodes ; donner l implémentation d une classe en conformité avec son interface et son contrat ; utiliser correctement l héritage et la généricité pour la définition de classes. Présentation du problème Dans le cadre de l implémentation du jeu d aventure Zork, il est nécessaire de définir la notion d objet : Certaines pièces contiennent des objets. Certains objets peuvent être emportés par le joueur, d autres non. Le joueur peut transporter des objets avec lui. Chaque objet a un poids. Le joueur ne peut transporter des objets que dans la mesure où le poids total des objets transportés ne dépasse pas une certaine limite fixée à l avance. Les pièces et les joueurs ayant en commun de pouvoir contenir des objets, on décide d implémenter ce comportement commun dans une classe générique nommée ArrayListConteneur. On décide ensuite d utiliser l héritage pour définir les classe Piece et Joueur. La documentation complète de la classe générique ArrayListConteneur figure en annexe. L implémentation des classes Piece et ObjetZork ne sera pas abordée dans le cadre de cette épreuve, la classe ObjetZork pourra cependant être utilisée dans la définition de la classe Joueur. 1 Définition de la classe ArrayListConteneur La classe générique ArrayListConteneur représente un conteneur pouvant contenir un nombre illimité d éléments. La structure de données interne utilisée pour mémoriser les objets contenus dans un conteneur est une ArrayList. Un ArrayListConteneur peut contenir plusieurs exemplaires d un même élément (au sens de cette classe, deux éléments représentent un même objet si ils sont equals ) et l ordre des éléments n est pas significatif (i.e. quelque soit l ordre dans lequel les éléments sont ajoutés, deux conteneurs contenant les mêmes éléments en même quantité seront considérés comme ayant le même contenu). Par ailleurs, un élément ne peut être ajouté à un conteneur que si cet ajout est considéré comme possible : dans ce but, la méthode ajoutpossible est définie afin de permettre de tester si les critères requis sont satisfaits par un objet donné. Exercice 1.1 Implémentation de la classe ArrayListConteneur. Donnez le code source complet de la classe ArrayListConteneur dont la documentation complète est donnée en annexe. Parmi l ensemble des méthodes figurant dans la documentation on se limitera aux méthodes suivantes : les deux constructeurs ajoutpossible(e oz) ajouter(e obj) retirer(object obj) M. Champesme Département d Informatique Institut Galilée 1

2 contientcombiende(object obj) getnbobjets() memecontenu(arraylistconteneur<?> c) equals(object o) clone() hashcode() 2 Implémentation de la classe Joueur On souhaite maintenant définir la classe Joueur, en réutilisant, grâce à l héritage et la généricité, les fonctionnalités définies pour la classe ArrayListConteneur. Dans le jeu Zork, un joueur est caractérisé par son nom, les objets qu il transporte avec lui dans son sac et la capacité maximale de son sac. Un joueur peut transporter dans son sac autant d objets qu il le souhaite, du moment que ces objets sont transportables (cf. méthode esttransportable() de la classe ObjetZork) et que le poids total de l ensemble des objets transportés ne dépasse pas la capacité maximale de son sac telle qu elle a été fixée à la création de cette instance de la classe Joueur. Exercice 2.1 Implémentation de la classe Joueur. Donnez le code source complet de la classe Joueur en faisant en sorte que cette classe possède toutes les caractéristiques définies dans la classe ArrayListConteneur, ainsi que les caractéristiques correspondant aux méthodes suivantes : un constructeur initialisant un Joueur ne possédant aucun objet un constructeur initialisant un Joueur possédant les objets présents dans une liste passée en paramètre (cf. constructeur analogue de la classe ArrayListConteneur une méthode String getnom() renvoyant le nom du Joueur une méthode int poidssac() renvoyant le poids total de tous les objets transportés une méthode int getmaxcapacite() renvoyant le poids maximum que ce Joueur peut transporter Vous devrez préciser sous forme de commentaires, le contrat associé au constructeur de cette classe (le contrat des autres méthodes n est pas demandé). A Documentation de la classe ArrayListConteneur<E> Voire page suivante. 2

3 Class ArrayListConteneur<E> public class ArrayListConteneur<E> extends java.lang.object implements java.lang.iterable<e>, java.lang.cloneable Implémentation d'un conteneur d'objets utilisant une ArrayList comme structure de données. Les éléments contenus ne sont pas ordonnés et un conteneur peut contenir plusieurs exemplaires d'un même élément (au sens de equals). Un conteneur ne peut pas contenir la valeur null. Invariant: getnbobjets() >= 0; estvide() <==> getnbobjets() == 0; (\forall E obj; ; contient(obj) <==> (contientcombiende(obj) > 0)); Constructor Summary ArrayListConteneur() Initialise un ArrayListConteneur vide. ArrayListConteneur(java.util.List<? extends E> list) Initialise un ArrayListConteneur de même contenu que la liste spécifiée. Method Summary void ajouter(e obj) Ajoute l'objet specifié à ce conteneur. void ajouter(e obj, int ncopies) Ajoute ncopies exemplaires de l'objet specifié à ce conteneur. boolean ajoutpossible(e oz) Indique si un exemplaire de l'objet spécifié peut être ajouté à ce conteneur. boolean ajoutpossible(e oz, int ncopies) Indique si ncopies exemplaires de l'objet spécifié peuvent être ajoutés à ce conteneur. ArrayListConteneur<E> clone() Renvoie un clone de ce conteneur. boolean contient(java.lang.object obj) Renvoie true si le conteneur contient au moins un exemplaire de l'objet specifié. int contientcombiende(java.lang.object obj) Renvoie le nombre d'exemplaires de l'objet specifié presents dans ce conteneur. boolean equals(java.lang.object o) Teste si l'objet spécifié est equals à ce conteneur. boolean estvide() Renvoie true si ce conteneur ne contient aucun objet.

4 int getnbobjets() Renvoie le nombre d'objets dans ce conteneur. int hashcode() Renvoie un code de hashage pour ce conteneur. java.util.iterator<e> iterator() Renvoie un itérateur sur les éléments de ce conteneur. boolean memecontenu(arraylistconteneur<?> c) Renvoie true si le ArrayListConteneur spécifié est non null et contient les mêmes objets (au sens de equals) en autant d'exemplaires. boolean retirer(java.lang.object obj) Retire un exemplaire de l'objet specifié de ce conteneur si cet objet y est present. int retirer(java.lang.object obj, int ncopies) Retire ncopies exemplaires de l'objet specifié de ce conteneur si cet objet y est present. java.lang.string tostring() Renvoie une représentation succincte de ce ArrayListConteneur sous forme de chaîne de caractères. Constructor Detail ArrayListConteneur public ArrayListConteneur() void vider() Retire de ce conteneur tous les objets qu'il contient. Initialise un ArrayListConteneur vide. estvide(); ArrayListConteneur public ArrayListConteneur(java.util.List<? extends E> list) Initialise un ArrayListConteneur de même contenu que la liste spécifiée. La liste spécifiée et ses éléments doivent être non null et tous les éléments de la liste doivent pouvoir être ajoutés à ce conteneur (au sens de la méthode ajoutpossible). Requires: list!= null; (\forall int i; i >= 0 && i < list.size(); list.get(i)!= null); (* Tous les éléments de list peuvent être ajoutés. *) this.getnbobjets() == list.size();

5 (\forall int i; i >= 0 && i < list.size(); contient(list.get(i))); (\forall E elt; contient(elt); list.contains(elt)); list - La liste contenant les éléments à placer dans ce conteneur. Throws: java.lang.nullpointerexception - si la liste spécifiée est null ou contient la valeur null. java.lang.illegalargumentexception - si certaines caractéristiques d'un des éléments de la liste spécifiée empèchent son ajout (i.e. si l'objet spécifié n'est pas null et que son ajout n'est pas possible au sens de ajoutpossible). Method Detail ajoutpossible public boolean ajoutpossible(e oz) Indique si un exemplaire de l'objet spécifié peut être ajouté à ce conteneur. Renvoie false si l'objet spécifié est null. Le résultat d'un appel à cette méthode pour un même paramètre peut varier au cours du temps en fonction des caractéristiques de ce conteneur, en particulier, la valeur renvoyée peut varier en fonction des éléments présents dans ce conteneur. Il est par exemple possible qu'un appel de cette méthode pour un objet déjà présent dans ce conteneur renvoie la valeur false. Néanmoins, il est garanti que, entre deux modifications successives de ce Conteneur, plusieurs appels à cette méthode pour un même objet renvoient le même résultat. L'implémentation fournie par cette classe renvoie true si et seulement si l'objet spécifié est non null. (oz == null) ==>!\result; \result <==> ajoutpossible(oz, 1); oz - L'objet à ajouter. true si l'objet est non null et peut être ajouté ; false sinon. ajoutpossible public boolean ajoutpossible(e oz, int ncopies) Indique si ncopies exemplaires de l'objet spécifié peuvent être ajoutés à ce conteneur. Renvoie false si l'objet spécifié est null. Le nombre d'exemplaires spécifié doit être strictement positif. Il est garanti que si un appel à cette méthode renvoie true tout appel pour le même objet et un nombre d'exemplaires inférieur renvoie aussi true ; de même il est garanti que si un appel à cette méthode renvoie false tout appel pour le même objet et un nombre d'exemplaires supérieur renvoie aussi false. Le résultat d'un appel à cette méthode pour un même paramètre peut varier au cours du temps en fonction des caractéristiques de ce conteneur, en particulier, la valeur renvoyée peut varier en fonction des éléments présents dans ce conteneur. Il est par exemple possible qu'un appel de cette méthode pour un objet déjà présent dans ce conteneur renvoie la valeur false.

6 Néanmoins, il est garanti que, entre deux modifications successives de ce conteneur, plusieurs appels à cette méthode pour un même objet et un même nombre d'exemplaires renvoient le même résultat. L'implémentation fournie par cette classe renvoie le même résultat que ajoutpossible(e obj) quelque soit le nombre d'exemplaires spécifié. Requires: ncopies > 0; (oz == null) ==>!\result; (ncopies == 1) ==> (\result <==> ajoutpossible(oz)); \result ==> ajoutpossible(oz); oz - L'objet à ajouter. ncopies - Le nombre d'exemplaires de l'objet à ajouter. true si l'objet est non null et que ncopies de l'objet peuvent être ajoutés ; false sinon. Throws: java.lang.illegalargumentexception - si ncopies est inférieur ou égal à 0. ajouter public void ajouter(e obj) Ajoute l'objet specifié à ce conteneur. Si l'objet est déjà présent, un exemplaire supplémentaire de cet objet y est ajouté. La presence d'un objet est testée en utilisant la methode equals. L'argument doit être non null et son ajout doit être possible au sens de la méthode ajoutpossible. Requires: ajoutpossible(obj); contient(obj); contientcombiende(obj) == \old(contientcombiende(obj)) + 1; obj - L'objet à ajouter dans ce conteneur Throws: java.lang.illegalargumentexception - si certaines caractéristiques de cet objets empèchent son ajout (i.e. si l'objet spécifié n'est pas null et que son ajout n'est pas possible au sens de ajoutpossible. java.lang.nullpointerexception - si l'objet spécifié est null.

7 ajouter public void ajouter(e obj, int ncopies) Ajoute ncopies exemplaires de l'objet specifié à ce conteneur. Si l'objet est déjà présent, ncopies exemplaires supplémentaires de cet objet y sont ajoutés. La presence d'un objet est testée en utilisant la methode equals. L'objet doit être non null et son ajout doit être possible au sens de la méthode ajoutpossible. ncopies doit être strictement positif. Requires: ncopies > 0; ajoutpossible(obj, ncopies); contient(obj); contientcombiende(obj) == \old(contientcombiende(obj)) + ncopies; obj - L'objet à ajouter dans ce conteneur ncopies - Le nombre d'exemplaires de l'objet à retirer de ce conteneur. Throws: java.lang.illegalargumentexception - si ncopies est inférieur ou égal à 0 ou si certaines caractéristiques de l'objet spécifié empèchent son ajout (i.e. si l'objet spécifié n'est pas null et que son ajout n'est pas possible au sens de ajoutpossible). java.lang.nullpointerexception - si l'objet spécifié est null. contient public boolean contient(java.lang.object obj) Renvoie true si le conteneur contient au moins un exemplaire de l'objet specifié. La présence d'un objet est testée en utilisant la méthode equals. Renvoie false si l'argument est null. \result <==> contientcombiende(obj) > 0; estvide() ==>!\result; obj - Objet dont on cherche à savoir s'il est present. true si ce conteneur possede au moins un exemplaire de l'objet specifié ; false sinon. contientcombiende public int contientcombiende(java.lang.object obj) Renvoie le nombre d'exemplaires de l'objet specifié presents dans ce conteneur. La presence

8 d'un objet est testée en utilisant la méthode equals. Renvoie 0 si l'argument est null. \result >= 0; (obj == null) ==> (\result == 0); contient(obj) <==> \result > 0;!contient(obj) <==> \result == 0; \result <= getnbobjets(); obj - Objet dont on cherche à connaitre le nombre d'exemplaires. le nombre d'exemplaires de l'objet specifié. estvide public boolean estvide() Renvoie true si ce conteneur ne contient aucun objet. \result <==> (getnbobjets() == 0); true si ce conteneur ne contient aucun objet ; false sinon. getnbobjets public int getnbobjets() Renvoie le nombre d'objets dans ce conteneur. Chaque occurence de chaque objet est comptée. \result >= 0; Le nombre d'objets dans ce conteneur. iterator public java.util.iterator<e> iterator() Renvoie un itérateur sur les éléments de ce conteneur. Specified by: iterator in interface java.lang.iterable<e> \result!= null;

9 Un itérateur sur les éléments de ce conteneur. memecontenu public boolean memecontenu(arraylistconteneur<?> c) Renvoie true si le ArrayListConteneur spécifié est non null et contient les mêmes objets (au sens de equals) en autant d'exemplaires. (c == null) ==>!\result; (getnbobjets()!= c.getnbobjets()) ==>!\result; c - Le conteneur à comparer avec ce conteneur. true si le conteneur spécifié contient les mêmes objets en autant d'exemplaires ; false sinon. retirer public boolean retirer(java.lang.object obj) Retire un exemplaire de l'objet specifié de ce conteneur si cet objet y est present. Renvoie true si cet objet était effectivement présent dans ce conteneur et que l'objet a pu être effectivement retiré ; renvoie false sinon. La présence d'un objet est testée en utilisant la méthode equals. Renvoie false si l'argument est null. (obj == null) ==>!\result; \old(contient(obj)) <==> \result; \old(contient(obj)) <==> (contientcombiende(obj) == \old(contientcombiende(obj)) - 1); \old(contientcombiende(obj) <= 1) <==>!contient(obj); \old(contientcombiende(obj) > 1) <==> contient(obj); obj - Objet dont un exemplaire doit être retirer de ce conteneur. true si cet objet etait effectivement present ; false sinon. retirer public int retirer(java.lang.object obj, int ncopies) Retire ncopies exemplaires de l'objet specifié de ce conteneur si cet objet y est present. Renvoie le nombre d'exemplaires de l'objet effectivement retirés. La présence d'un objet est testée en utilisant la méthode equals. Renvoie 0 si l'argument est null (et ncopies est supérieur ou égal à

10 0) ou si ncopies est égal à 0. ncopies doit être supérieur ou égal à 0. Requires: ncopies >= 0; obj == null ==> \result == 0; \old(contient(obj)) && ncopies > 0 <==> \result > 0; \result == (\old(contientcombiende(obj)) - contientcombiende(obj)); contientcombiende(obj) == Math.max(0, \old(contientcombiende(obj)) - ncopies); \old(contientcombiende(obj) <= ncopies) ==>!contient(obj); \old(contientcombiende(obj) > ncopies) <==> contient(obj); obj - Objet dont un exemplaire doit être retirer de ce conteneur ncopies - Nombre d'exemplaires de l'objet spécifié à retirer de ce conteneur. Le nombre d'exemplaires de l'objet effectivement retirés de ce conteneur. Throws: java.lang.illegalargumentexception - si ncopies est strictement négatif vider public void vider() Retire de ce conteneur tous les objets qu'il contient. estvide(); equals public boolean equals(java.lang.object o) Teste si l'objet spécifié est equals à ce conteneur. Pour qu'il y ait égalité entre ce conteneur et l'objet spécifié, il est nécessaire (mais non suffisant) que l'objet spécifié soit un ArrayListConteneur de même contenu (au sens de la méthode memecontenu). Selon les classes héritant de cette classe, d'autres caractéristiques de ces classes peuvent être prises en compte dans la comparaison. Deux conteneurs contenant les mêmes objets en autant d'exemplaires peuvent donc ne pas être equals. L'implémentation fournie par cette classe remplie le contrat en déclarant deux ArrayListConteneur equals si et seulement si ce sont des instances de la même sous-classe de ArrayListConteneur contenant les mêmes objets en autant d'exemplaires. En conséquence, une instance de la classe ArrayListConteneur ne peut-être equals qu'à des instances de ArrayListConteneur. Les sous-classes de ArrayListConteneur peuvent donc hériter cette méthode sans redéfinition tout en respectant à la fois le contrat défini dans la classe Object (y

11 compris la symétrie et la transitivité) et celui défini dans cette classe.!(o instanceof ArrayListConteneur<?>) ==>!\result; \result ==> this.memecontenu((arraylistconteneur<?>) o); this.getclass().equals(arraylistconteneur.class) ==> (\result <==> ((o!= null) && o.getclass().equals(this.getclass()) && this.memecontenu((arraylistconteneur<?>) o))); o - L'objet à comparer à ce conteneur false si l'objet spécifié n'est pas un ArrayListConteneur ou bien est un conteneur ne contenant pas les mêmes objets en autant d'exemplaires ou bien possède certaines caractéristiques différentes de celles de l'objet spécifié ; true seulement si l'objet spécifié est un ArrayListConteneur contenant les mêmes objets en autant d'exemplaires. clone public ArrayListConteneur<E> clone() Renvoie un clone de ce conteneur. L'implémentation fournie par cette classe respecte le contrat défini dans la classe Object relativement à l'implémentation de equals fournie par cette classe. Un clone de ce conteneur. hashcode public int hashcode() Renvoie un code de hashage pour ce conteneur. L'implémentation fournie par cette classe respecte le contrat défini dans la classe Object relativement à l'implémentation de equals fournie par cette classe. Un code de hashage pour ce conteneur. tostring public java.lang.string tostring() Renvoie une représentation succincte de ce ArrayListConteneur sous forme de chaîne de caractères. une représentation succincte de ce ArrayListConteneur

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) CLASSE RACINE Object ancêtre de toutes les classes RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) définit donc des méthodes héritées par toutes

Plus en détail

Chapitre 10. Les interfaces Comparable et Comparator 1

Chapitre 10. Les interfaces Comparable et Comparator 1 Chapitre 10: Les interfaces Comparable et Comparator 1/5 Chapitre 10 Les interfaces Comparable et Comparator 1 1 Ce chapitre a été extrait du document "Objets, Algorithmes, Patterns" de [René Lalement],

Plus en détail

Programmation par les Objets en Java

Programmation par les Objets en Java Programmation par les Objets en Java Najib TOUNSI Les classes en Java (TD 3) I. Notion de classe I.1 Classe, champs, méthodes, instanciation, this, private vs. public. Créer une classe Point (coordonnée

Plus en détail

Introduction. Les méthodes. Les méthodes. Identité et égalité. Identité et égalité. La copie d'objets. Identité et égalité.

Introduction. Les méthodes. Les méthodes. Identité et égalité. Identité et égalité. La copie d'objets. Identité et égalité. Introduction La classe object Tous les objets Java héritent de la classe java.lang.object. Elle garantit que tout objet Java contient quelques méthodes fondamentales duplication comparaison Chaque classe

Plus en détail

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)

Programmer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes

Plus en détail

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface

Plus en détail

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. Encapsulation L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. La visibilité dépend des membres : certains membres peuvent être visibles et d'autres

Plus en détail

Programmation avec des objets : Cours 7. Menu du jour

Programmation avec des objets : Cours 7. Menu du jour 1 Programmation avec des objets : Cours 7 Menu du jour 1. Retour sur la classe Liste 2. Précisions sur l interface 3. Difficultés dans le cas d erreurs 4. Soulever des exceptions 5. Utilisation des Listes

Plus en détail

Java Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites

Java Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites Java Licence Professionnelle 2009-2010 Cours 7 : Classes et méthodes abstraites 1 Java Classes et méthodes abstraites - Le mécanisme des classes abstraites permet de définir des comportements (méthodes)

Plus en détail

Chapitre V. Les classes : Object, Vector, etc.

Chapitre V. Les classes : Object, Vector, etc. Chapitre V Les classes de base Les classes : Object, Vector, etc. Plan La classe Object Les collections La classe ArrayList La classe Vector Les classes Wrappers Les classes String et StringBuffer La classe

Plus en détail

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez

Plus en détail

Premiers Pas en Programmation Objet : les Classes et les Objets

Premiers Pas en Programmation Objet : les Classes et les Objets Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.

Plus en détail

Utilisation d objets : String et ArrayList

Utilisation d objets : String et ArrayList Chapitre 6 Utilisation d objets : String et ArrayList Dans ce chapitre, nous allons aborder l utilisation d objets de deux classes prédéfinies de Java d usage très courant. La première, nous l utilisons

Plus en détail

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections

Plus en détail

Une introduction à Java

Une introduction à Java Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)

Plus en détail

Programmation Par Objets

Programmation Par Objets Programmation Par Objets Structures de données package java.util B. Carré Polytech Lille 1 Tableaux et structures de données Tableaux «Objets» taille fixe type des éléments : primitif (homogène) ou objets

Plus en détail

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Polymorphisme, la classe Object, les package et la visibilité en Java... 1 Polymorphisme, la classe Object, les package et la visibilité en Java. Polymorphisme, la classe Object, les package et la visibilité en Java.... 1 Polymorphisme.... 1 Le DownCast... 4 La Classe Object....

Plus en détail

Page 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T>

Page 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T> Page 1 sur 5 TP3 Lectures préalables : l Java_II l tutorial Interfaces Thèmes du TP : l la classe Object l Vector l Stack Une pile d'objects Les éléments de la classe Pile sont maintenant des instances

Plus en détail

Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)

Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés) Introduction à la POO 1. Histoire de la POO 9 2. Historique du 12 La conception orientée objet 1. Approche procédurale et décomposition fonctionnelle 13 2. La transition vers l'approche objet 14 3. Les

Plus en détail

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la

Plus en détail

Corrigé des exercices sur les références

Corrigé des exercices sur les références Corrigé des exercices sur les références Exercice 3.1.1 dessin Pour cet exercice, vous allez dessiner des structures de données au moyen de petits schémas analogues à ceux du cours, comportant la pile

Plus en détail

Héritage presque multiple en Java (1/2)

Héritage presque multiple en Java (1/2) Héritage presque multiple en Java (1/2) Utiliser deux classes ou plus dans la définition d'une nouvelle classe peut se faire par composition. class Etudiant{ int numero; Diplome d; float passeexamen(examen

Plus en détail

Auto-évaluation Programmation en Java

Auto-évaluation Programmation en Java Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN

Plus en détail

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ; CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe

Plus en détail

F. Barthélemy. 17 mai 2005

F. Barthélemy. 17 mai 2005 Typage de la généricité en Java F. Barthélemy 17 mai 2005 1 Le shéma général La g én éricit é en Java est un ajout r éalis é sur un langage existant depuis d éjà une dizaine d ann ées, avec des contraintes

Plus en détail

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations

Plus en détail

Java 1.5 : principales nouveautés

Java 1.5 : principales nouveautés Cours 6 - TEP - UPMC - 2008/2009 p. 1/34 Java 1.5 : principales nouveautés classes paramétrées : generics encapsulation des valeurs de types primitifs : auto[un]boxing itération sur les boucles types énumérés

Plus en détail

TD/TP PAC - Programmation n 3

TD/TP PAC - Programmation n 3 Université Paris Sud Licence d informatique/iup-miage2 - Année 2004-2005 auteur : Frédéric Vernier semaine : 11-16 octobre 2004 conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html

Plus en détail

Programmation Objet I

Programmation Objet I 2002-2003 UFR Mathématique de la Décision Deuxième Année de DEUG Science mention MASS Programmation Objet I Fabrice Rossi et Fabien Napolitano c Fabrice Rossi et Fabien Napolitano, 2002-2003 Le code de

Plus en détail

Tp 1 correction. Structures de données (IF2)

Tp 1 correction. Structures de données (IF2) Tp 1 correction Structures de données (IF2) Remarque générale : compilez et exécutez le code au-fur-et-à mesure de son écriture. Il est plus facile de corriger une petite portion de code délimitée que

Plus en détail

TD3: tableaux avancées, première classe et chaînes

TD3: tableaux avancées, première classe et chaînes TD3: tableaux avancées, première classe et chaînes de caractères 1 Lestableaux 1.1 Élémentsthéoriques Déclaration des tableaux Pour la déclaration des tableaux, deux notations sont possibles. La première

Plus en détail

Plan. Exemple: Application bancaire. Introduction. OCL Object Constraint Language Le langage de contraintes d'uml

Plan. Exemple: Application bancaire. Introduction. OCL Object Constraint Language Le langage de contraintes d'uml OCL Object Constraint Language Le langage de contraintes d'uml Plan 1. Introduction 2. Les principaux concepts d'ocl Object Constraint Language 1 Object Constraint Language 2 Exemple: une application bancaire

Plus en détail

Présentation. Au programme. Fonctionnement. A l issue de ce module vous devriez...

Présentation. Au programme. Fonctionnement. A l issue de ce module vous devriez... Au programme Conception Orientée Objet Jean-Christophe Routier Licence mention Informatique Université Lille 1 Présentation L UE COO est le prolongement immédiat de l UE POO du S4 informatique. cf. http://portail.fil.univ-lille1.fr/portail/ls4/poo

Plus en détail

TP1 : Initiation à Java et Eclipse

TP1 : Initiation à Java et Eclipse TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les

Plus en détail

Introduction au langage de programmation Java

Introduction au langage de programmation Java Introduction au langage de programmation Java Christian Bac, Denis Conan CSC 4002 Octobre 2014 Revision : 996 Introduction au langage de programmation Java Sommaire du cours 1 Introduction à Java.............................................................

Plus en détail

Java Licence Professionnelle CISII, 2009-10

Java Licence Professionnelle CISII, 2009-10 Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation

Plus en détail

Projet de programmation (IK3) : TP n 1 Correction

Projet de programmation (IK3) : TP n 1 Correction Projet de programmation (IK3) : TP n 1 Correction Semaine du 20 septembre 2010 1 Entrées/sorties, types de bases et structures de contrôle Tests et types de bases Tests et types de bases (entiers) public

Plus en détail

Facultés Universitaires Notre-Dame de la Paix. Conception et Programmation Orientées- Object

Facultés Universitaires Notre-Dame de la Paix. Conception et Programmation Orientées- Object Facultés Universitaires Notre-Dame de la Paix Conception et Programmation Orientées- Object 2008-2009 RÉSUMÉ PRATIQUE... 4 CLASSE OBJET... 4 NOTION D HÉRITAGE... 4 LE POLYMORPHISME... 5 LES CLASSES ABSTRAITES...

Plus en détail

Cours 1: Java et les objets

Cours 1: Java et les objets Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/

Plus en détail

4. Groupement d objets

4. Groupement d objets Conception objet en Java avec BlueJ une approche interactive 4. Groupement d objets Collections et itérateurs David J. Barnes, Michael Kölling version française: Patrice Moreaux Rédigé avec 1.0 Principaux

Plus en détail

Objets et Programmation. origine des langages orientés-objet

Objets et Programmation. origine des langages orientés-objet Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève

Plus en détail

Package Java.util Classe générique

Package Java.util Classe générique Package Java.util Classe générique 1 Classe Vector La taille est dynamique: dès qu un tableau vectoriel est plein, sa taille est doublée, triplée, etc. automatiquement Les cases sont de type Object add(object

Plus en détail

Bases Java - Eclipse / Netbeans

Bases Java - Eclipse / Netbeans Institut Galilée PDJ Année 2014-2015 Master 1 Environnements Java T.P. 1 Bases Java - Eclipse / Netbeans Il existe plusieurs environnements Java. Il est ESSENTIEL d utiliser la bonne version, et un environnement

Plus en détail

Corrigés des premiers exercices sur les classes

Corrigés des premiers exercices sur les classes Corrigés des premiers exercices sur les classes Exercice 2.1.1 utilisation d une classe Voici le texte d une classe représentant de façon sommaire un compte bancaire et les opérations bancaires courantes.

Plus en détail

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40 Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne gauthier.picard@emse.fr

Plus en détail

2 e édition JAVA 5 et 6. Jérôme Bougeault. TSoft et Groupe Eyrolles, 2003, 2008, ISBN : 978-2-21212250-3

2 e édition JAVA 5 et 6. Jérôme Bougeault. TSoft et Groupe Eyrolles, 2003, 2008, ISBN : 978-2-21212250-3 2 e édition JAVA 5 et 6 Jérôme Bougeault TSoft et Groupe Eyrolles, 2003, 2008, ISBN : 978-2-21212250-3 Classes et objets Les constructeurs Propriétés Les méthodes L héritage Les interfaces Les relations

Plus en détail

OCL - Object Constraint Language

OCL - Object Constraint Language OCL - Object Constraint Language Laëtitia Matignon laetitia.matignon@univ-lyon1.fr Département Informatique - Polytech Lyon Université Claude Bernard Lyon 1 2012-2013 Laëtitia Matignon SIMA - OCL - Object

Plus en détail

Exclusion Mutuelle. Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 9 février 2011

Exclusion Mutuelle. Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 9 février 2011 Arnaud Labourel Courriel : arnaud.labourel@lif.univ-mrs.fr Université de Provence 9 février 2011 Arnaud Labourel (Université de Provence) Exclusion Mutuelle 9 février 2011 1 / 53 Contexte Epistémologique

Plus en détail

Exercices sur les interfaces

Exercices sur les interfaces Exercices sur les interfaces Fabrice Rossi 18 octobre 1999 1 Le type Object 1.1 Manipulations élémentaires Exercice 1.1 : Indiquer l affichage produit par le programme suivant : public class UpCast1 {

Plus en détail

RMI le langage Java XII-1 JMF

RMI le langage Java XII-1 JMF Remote Method Invocation (RMI) XII-1 Introduction RMI est un ensemble de classes permettant de manipuler des objets sur des machines distantes (objets distants) de manière similaire aux objets sur la machine

Plus en détail

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object) Quelques patterns pour la persistance des objets avec DAO Ce cours présente des modèles de conception utilisés pour effectuer la persistance des objets Université de Nice Sophia-Antipolis Version 1.4 30/8/07

Plus en détail

Généricité. en Java. (polymorphisme paramétrique) Philippe GENOUD UJF Janvier 2015 1

Généricité. en Java. (polymorphisme paramétrique) Philippe GENOUD UJF Janvier 2015 1 (polymorphisme paramétrique) en Java Philippe GENOUD UJF Janvier 2015 1 Motivations Supposons que l'on développe du code pour gérer une file d'attente (FIFO First In First Out) et que l'on veuille utiliser

Plus en détail

SHERLOCK 7. Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5

SHERLOCK 7. Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5 SHERLOCK 7 Version 1.2.0 du 01/09/09 JAVASCRIPT 1.5 Cette note montre comment intégrer un script Java dans une investigation Sherlock et les différents aspects de Java script. S T E M M E R I M A G I N

Plus en détail

P r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 )

P r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 ) P r ob lé m a t iq u e d e la g é n é r icit é les versions de Java antérieures à 1.5 permettaient de créer des classes de structures contenant n'importe quels types d'objet : les collections (classes

Plus en détail

Design patterns. Design patterns - définition. Design patterns - avantages

Design patterns. Design patterns - définition. Design patterns - avantages Design patterns Conception UML Implantation Java Anne Lapujade 1 Design patterns - définition 2 v Objectif : proposer des solutions standardisées à des problèmes de conception classiques v Design pattern

Plus en détail

Programmation Réseau. Sécurité Java. Jean-Baptiste.Yunes@univ-paris-diderot.fr. UFR Informatique 2012-2013. jeudi 4 avril 13

Programmation Réseau. Sécurité Java. Jean-Baptiste.Yunes@univ-paris-diderot.fr. UFR Informatique 2012-2013. jeudi 4 avril 13 Programmation Réseau Sécurité Java Jean-Baptiste.Yunes@univ-paris-diderot.fr UFR Informatique 2012-2013 Java Sécurité? différentes sécurités disponibles et contrôlables intégrité contrôle d accès signature/authentification/cryptographie

Plus en détail

Un ordonnanceur stupide

Un ordonnanceur stupide Un ordonnanceur simple Université Paris Sud L objet des exercices qui suivent est de créer un ordonanceur implantant l algorithme du tourniquet ( round-robin scheduler ). La technique utilisée pour élire

Plus en détail

Java Licence Professionnelle CISII, 2009-2010. Cours 2 : Classes et Objets

Java Licence Professionnelle CISII, 2009-2010. Cours 2 : Classes et Objets Licence Professionnelle CISII, 2009-2010 Cours 2 : Classes et Objets 1 Classes et Objets Objectifs des LOO : - Manipuler des objets - Découper les programmes suivant les types des objets manipulés - Regrouper

Plus en détail

Langage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2

Langage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2 Langage et Concepts de Programmation Objet Travaux Dirigés no2 Pôle Informatique École Nationale Supérieure des Mines de St-Etienne Vous trouverez plus de détails sur les concepts abordés lors de ce TD

Plus en détail

Définition des Webservices Ordre de paiement par email. Version 1.0

Définition des Webservices Ordre de paiement par email. Version 1.0 Définition des Webservices Ordre de paiement par email Version 1.0 Rédaction, Vérification, Approbation Rédaction Vérification Approbation Nom Date/Visa Nom Date/Visa Nom Date/Visa Historique du document

Plus en détail

Classes et Objets en Ocaml.

Classes et Objets en Ocaml. Classes et Objets en Ocaml. Didier Rémy 2001-2002 http://cristal.inria.fr/ remy/mot/2/ http://www.enseignement.polytechnique.fr/profs/informatique/didier.remy/mot/2/ Cours Exercices Slide 1 1. Objets 2.

Plus en détail

Initiation à JAVA et à la programmation objet. raphael.bolze@ens-lyon.fr

Initiation à JAVA et à la programmation objet. raphael.bolze@ens-lyon.fr Initiation à JAVA et à la programmation objet raphael.bolze@ens-lyon.fr O b j e c t i f s Découvrir un langage de programmation objet. Découvrir l'environnement java Découvrir les concepts de la programmation

Plus en détail

Programmation par composants (1/3) Programmation par composants (2/3)

Programmation par composants (1/3) Programmation par composants (2/3) Programmation par composants (1/3) La programmation par composant vise le développement de logiciel par aggrégation de briques logicielles existantes est indépendante de la POO La programmation par composant

Plus en détail

Langage Java. Classe de première SI

Langage Java. Classe de première SI Langage Java Table des matières 1. Premiers pas...2 1.1. Introduction...2 1.2. Mon premier programme...2 1.3. Les commentaires...2 2. Les variables et les opérateurs...2 3. La classe Scanner...3 4. Les

Plus en détail

Remote Method Invocation Les classes implémentant Serializable

Remote Method Invocation Les classes implémentant Serializable Parallélisme Architecture Eric Goubault Commissariat à l Energie Atomique Saclay Classe qui implémente la méthode distante (serveur): - dont les méthodes renvoient un objet serializable - ou plus généralement

Plus en détail

Gestion distribuée (par sockets) de banque en Java

Gestion distribuée (par sockets) de banque en Java Gestion distribuée (par sockets) de banque en Java Université Paris Sud Rappel sur la solution locale de gestion simple de banque L objet de cet exercice était de créer une application java qui implante

Plus en détail

2. Comprendre les définitions de classes

2. Comprendre les définitions de classes Conception objet en Java avec BlueJ une approche interactive 2. Comprendre les définitions de classes Analyser le contenu des classes David J. Barnes, Michael Kölling version française: Patrice Moreaux

Plus en détail

Chapitre 2. Classes et objets

Chapitre 2. Classes et objets Chapitre 2: Classes et Objets 1/10 Chapitre 2 Classes et objets Chapitre 2: Classes et Objets 2/10 Approche Orientée Objet Idée de base de A.O.O. repose sur l'observation de la façon dont nous procédons

Plus en détail

Recherche dans un tableau

Recherche dans un tableau Chapitre 3 Recherche dans un tableau 3.1 Introduction 3.1.1 Tranche On appelle tranche de tableau, la donnée d'un tableau t et de deux indices a et b. On note cette tranche t.(a..b). Exemple 3.1 : 3 6

Plus en détail

Plateforme PAYZEN. Définition de Web-services

Plateforme PAYZEN. Définition de Web-services Plateforme PAYZEN Définition de Web-services Ordre de paiement Version 1.1 Rédaction, Vérification, Approbation Rédaction Vérification Approbation Nom Date/Visa Nom Date/Visa Nom Date/Visa Lyra-Network

Plus en détail

Création d objet imbriqué sous PowerShell.

Création d objet imbriqué sous PowerShell. Création d objet imbriqué sous PowerShell. Par Laurent Dardenne, le 13/01/2014. Niveau Ce tutoriel aborde la création d objet composé, c est-à-dire que certains de ses membres seront eux-mêmes des PSObjects.

Plus en détail

Remote Method Invocation (RMI)

Remote Method Invocation (RMI) Remote Method Invocation (RMI) TP Réseau Université Paul Sabatier Master Informatique 1 ère Année Année 2006/2007 Plan Objectifs et Inconvénients de RMI Fonctionnement Définitions Architecture et principe

Plus en détail

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004 Questionnaire d'examen final INF1101 Sigle du cours Nom : Signature : Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004 Professeur(s)

Plus en détail

Applet pour visualiser les variables «automate» notifiées

Applet pour visualiser les variables «automate» notifiées Applet pour visualiser les variables «automate» notifiées Sommaire 1. Introduction...2 2. Lecture de variables «automate» notifiées...2 2.1. IHM servant au test :...2 2.2. Codage de l'applet :...2 3. Codage

Plus en détail

Bases du langage. Historique Applications et applets Éléments de base du langage Classes et objets Les exceptions

Bases du langage. Historique Applications et applets Éléments de base du langage Classes et objets Les exceptions Langage JAVA Bases du langage Opérations sur les fichiers Réseau Multi-tâche Logiciel: interfaces... Gestion des périphériques (méthodes natives) Accès aux bases de données Bases du langage Historique

Plus en détail

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

INTRODUCTION A JAVA. Fichier en langage machine Exécutable INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du

Plus en détail

Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée

Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée forax at univ-mlv dot fr - ParisJUG Java.next() - Mars 2012 What Else? Lambda == Inner class? Java a des lambdas depuis la version 1.1 Exemple utilisant

Plus en détail

[APPLICATON REPARTIE DE VENTE AUX ENCHERES]

[APPLICATON REPARTIE DE VENTE AUX ENCHERES] 2012 Polytech Nice- Sophia El Hajji Khalil Yousfi Hichem SI4 - Log [APPLICATON REPARTIE DE VENTE AUX ENCHERES] Sommaire Architecture de l application... 3 Le Serveur... 3 Le Client... 4 Passage en CORBA...

Plus en détail

as Architecture des Systèmes d Information

as Architecture des Systèmes d Information Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes

Plus en détail

PROGRAMMATION PAR OBJETS

PROGRAMMATION PAR OBJETS PROGRAMMATION PAR OBJETS Java Environnement et constructions spécifiques Walter Rudametkin Maître de Conférences Bureau F011 Walter.Rudametkin@polytech-lille.fr B. Carré Polytech Lille 2 Java (Sun 1995)

Plus en détail

Programmation Orientée Objet application au langage Java Version Novembre 2007

Programmation Orientée Objet application au langage Java Version Novembre 2007 Programmation Orientée Objet application au langage Java Version Novembre 2007 Mickaël BARON - 2007 mailto:baron.mickael@gmail.com ou mailto:mickael.baron@serli.com SERLI informatique SERLI : www.serli.com

Plus en détail

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry. : Java Agent DEvelopment framework Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.fr Introduction à la plateforme JADE 1) Modèle d agent 2) Services 3) Norme FIPA

Plus en détail

Alfstore workflow framework Spécification technique

Alfstore workflow framework Spécification technique Alfstore workflow framework Spécification technique Version 0.91 (2012-08-03) www.alfstore.com Email: info@alfstore.com Alfstore workflow framework 2012-10-28 1/28 Historique des versions Version Date

Plus en détail

Threads. Threads. USTL http://www.lifl.fr/ routier 1

Threads. Threads. USTL http://www.lifl.fr/ routier 1 Threads USTL http://www.lifl.fr/ routier 1 Rappels - Définitions un Process est un programme qui tourne et dispose de ses propres ressources mémoire. OS multi-tâche plusieurs process en concurrence un

Plus en détail

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7

Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7 Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin

Plus en détail

INF2015 Développement de logiciels dans un environnement Agile. Examen intra 20 février 2014 17:30 à 20:30

INF2015 Développement de logiciels dans un environnement Agile. Examen intra 20 février 2014 17:30 à 20:30 Examen intra 20 février 2014 17:30 à 20:30 Nom, prénom : Code permanent : Répondez directement sur le questionnaire. Question #1 5% Quelle influence peut avoir le typage dynamique sur la maintenabilité

Plus en détail

OpenPaaS Le réseau social d'entreprise

OpenPaaS Le réseau social d'entreprise OpenPaaS Le réseau social d'entreprise Spécification des API datastore SP L2.3.1 Diffusion : Institut MinesTélécom, Télécom SudParis 1 / 12 1OpenPaaS DataBase API : ODBAPI...3 1.1Comparaison des concepts...3

Plus en détail

Cours Composant 2. Qualité logicielle et spécications algébriques

Cours Composant 2. Qualité logicielle et spécications algébriques UPMC Paris Universitas Master Informatique STL Cours Composant 2. Qualité logicielle et spécications algébriques c 2005-2008 Frédéric Peschanski UPMC Paris Universitas 24 février 2008 c 2005-2008 Frédéric

Plus en détail

TD/TP PAC - Programmation n 3

TD/TP PAC - Programmation n 3 Université Paris Sud Licence d informatique/iup-miage2 Année 2004-2005 Auteur : Frédéric Vernier Semaine : 11-16 octobre 2004 Conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html

Plus en détail

Serveur d'archivage 2007 Installation et utilisation de la BD exist

Serveur d'archivage 2007 Installation et utilisation de la BD exist Type du document Procédure d'installation Auteur(s) Eric Bouladier Date de création 26/02/20007 Domaine de diffusion tous Validé par Equipe Versions Date Auteur(s) Modifications V1.00 26/02/2007 Eric Bouladier

Plus en détail

Application web de gestion de comptes en banques

Application web de gestion de comptes en banques Application web de gestion de comptes en banques Objectif Réaliser une application Web permettant à un client de gérer ses comptes en banque Diagramme de cas d'utilisation 1 Les cas d'utilisation Connexion

Plus en détail

Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java

Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java Info0604 Programmation multi-threadée Cours 5 Programmation multi-threadée en Java Pierre Delisle Université de Reims Champagne-Ardenne Département de Mathématiques et Informatique 18 février 2015 Plan

Plus en détail

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Structure d un programme et Compilation Notions de classe et d objet Syntaxe Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types

Plus en détail

Java Licence professionnelle CISII, 2009-2010

Java Licence professionnelle CISII, 2009-2010 Java Licence professionnelle CISII, 2009-2010 Cours 6 : le paquetage (package) Cours inspiré des cours de Richard Grin, Antoine Tabbone et Hazel Everett 1 Définition - Les classes Java sont regroupées

Plus en détail

Arbres binaires de recherche

Arbres binaires de recherche 1 arbre des comparaisons 2 recherche dichotomique l'arbre est recalculé à chaque recherche 2 5 3 4 7 9 1 6 1 2 3 4 5 6 7 9 10 conserver la structure d'arbre au lieu de la reconstruire arbre binaire de

Plus en détail

Généralités sur le Langage Java et éléments syntaxiques.

Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...

Plus en détail

.NET - Classe de Log

.NET - Classe de Log .NET - Classe de Log Classe permettant de Logger des données Text Dans tous les projets, il est indispensable de pouvoir stocker de l'information textuelle : Pour le suivi des erreurs Pour le suivi de

Plus en détail

Programmation en Java IUT GEII (MC-II1) 1

Programmation en Java IUT GEII (MC-II1) 1 Programmation en Java IUT GEII (MC-II1) 1 Christophe BLANC - Paul CHECCHIN IUT Montluçon Université Blaise Pascal Novembre 2009 Christophe BLANC - Paul CHECCHIN Programmation en Java IUT GEII (MC-II1)

Plus en détail

EJB3.1 - ORM - Object-Relational Mapping

EJB3.1 - ORM - Object-Relational Mapping EJB3.1 - ORM - Object-Relational Mapping Chapitres traités Association d'une entité Durant cette étude, nous passerons en revue les bases des ORM (Object-Relational Mapping), qui consistent essentiellement

Plus en détail

La gestion de la persistance avec Hibernate. Hibernate et la gestion de persistance. La gestion de la persistance (1/2) Introduction

La gestion de la persistance avec Hibernate. Hibernate et la gestion de persistance. La gestion de la persistance (1/2) Introduction La gestion de la persistance avec et la gestion de persistance Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon - BP 540 76058 LE HAVRE CEDEX Claude.Duvallet@gmail.com

Plus en détail