Fichiers, flots et entrées/sorties. paquetage java.io
|
|
- Christian Damours
- il y a 6 ans
- Total affichages :
Transcription
1 Fichiers, flots et entrées/sorties paquetage java.io
2 Les fichiers, classe File Cette classe représente un «chemin abstrait vers un fichier» ; le terme «abstrait» signifie indépendant du système d exploitation ; cette classe permet de manipuler les fichiers de la même manière, quelle que soit le système d exploitation ; représente aussi bien les fichiers que les répertoires.
3 Les fichiers, class File L existence de fichier ou la correction du chemin n est pas vérifié lors de la création ; la validité du chemin est testée soit par des des méthodes de File, soit quand on essaye de lire dans le fichier construire un objet File avec un chemin complet nécessite de mettre ce chemin suivant la syntaxe du système à ne pas faire utiliser Class(Loader).getResource() utiliser JFileChooser demande le fichier en ligne de commande
4 Les fichiers, classe File Permet de tester les métadonnées du fichier : length, canwrite, canread, exists, isdirectory, isfile permet d obtenir la représentation du fichier : getcanonicalpath, getparent, getname, getabsolutefile
5 Les fichiers, classe File Permet de créer, renommer et supprimer des fichiers ou répertoires : createnewfile, mkdir, mkdirs, renameto, setlastmodified on peut dire à la machine virtuelle de supprimer le fichier à sa terminaison normale avec deleteonexit ; on peut créer un fichier temporaire avec createtempfile.
6 Les fichiers, classe File On peut lister les fichiers d un répertoire avec la méthode listfiles ou list ; on peut peut ne lister que les fichiers correspondant à un certain critère en donnant un objet implémentant l interface FileFilter ou l interface FilenameFilter comme argument à ces méthodes.
7 Exemple // Affiche tous les fichiers.java de /var/tmp File temp = new File("/var/tmp"); FilenameFilter filter = new FilenameFilter() { public boolean accept(file f,string name) { return name.endswith(".java"); } }; String[] sources = temp.listfiles(filter); System.out.println(Arrays.asList(sources));
8 Les flots ou flux Un flot est une suite d «éléments», les uns à la suite des autres ; un flot en entrée permet de lire des éléments ; un flot en sortie permet d écrire des éléments.
9 Il y a deux grandes classes de flots : Les flots en java les flots d éléments binaires, sous-classes de InputStream et OutputStream ; les flots de caractères unicode, sous-classes de Reader et Writer ; dans chaque famille, il y a des flots concrets, et des filtres ; les filtres sont des flots ajoutant des fonctionnalités à d autres flots.
10 InputStream (binaire) Cette classe est la classe abstraite parente de tous les flots binaires en entrée ; elle contient des méthodes de lecture read : bloquantes ; lisent au plus le nombre d octets demandés ; renvoient le nombre d octets lus (à tester!!!) ou l octet lu pour read() ; renvoient -1 en fin de flot lèvent IOException en cas d erreur.
11 Exemple byte[] buffer // des bytes car flot binaire buffer = new byte[100]; // demande au plus 100 octets int ans = System.in.read(buffer); if (ans == -1) // fin de fichier return; /* demande ce qu il manque pour faire 100, en le stockant à partir de ans */ System.in.read(buffer,ans,100-ans); // on est toujours pas sur d'avoir lu 100 octets
12 InputStream La méthode close permet de fermer un flux (et comme en système de finaliser l'écriture et libérer la ressource) ; la méthode available renvoie le nombre d octets disponibles i.e. read non bloquant pour ce nombre d octets (bref une information non fiable) ; les méthodes mark et reset permettent de marquer le flux à la position courante pour y retourner, skip de sauter des octets ; la méthode marksupported indique si ce mécanisme est implémenté.
13 Reader (caractères) Cette classe est la classe abstraite parente de tous les flots de caractères en entrée ; elle contient des méthodes de lecture read : bloquantes ; lisent au plus le nombre de caractères demandés ; renvoient le nombre de caractères lus ( ) ou le caractère lu pour read() ; renvoient -1 en fin de flot lève IOException en cas d erreur.
14 Reader La méthode close permet de fermer un flux ; la méthode ready indique si au moins un caractère est disponible (idem non fiable) ; les méthodes mark et reset permettent de marquer le flux à la position courante pour y retourner, skip de sauter des caractères ; la méthode marksupported indique si ce mécanisme est implémenté.
15 OutputStream/Writer Ces classes sont les classes abstraites parentes de tous les flots d octets ou caractères en sortie ; elle contient des méthodes de lecture write : bloquantes ; écrivent exactement le nombre de caractères demandés ; renvoient void ; les Writer peuvent écrire des String lèvent IOException en cas d erreur ; close permet de fermer le flot ; flush de vider les caches.
16 Exemple byte[] buffer = new byte[] {1,2,3,4}; // écrit 0 System.out.write(0); // écrit System.out.write(buffer); // écrit 2 3 System.out.write(buffer,1,2); // vide les caches System.out.flush(); char[] buffer = new char[] { a, b, c, d }; Writer writer = // écrit r writer.write( r ); // écrit abcd writer.write(buffer); // écrit Hello writer.write("hello"); // ferme le flot writer.close();
17 Flots d'un fichier Les classes FileReader, FileWriter, FileInputStream et FileOutputStream permettent de lire et écrire dans un fichier ; pour les FileReader et FileWriter, le codage des caractères choisi est le codage par défaut du système
18 Flots d'un tableau Les classes CharArrayReader, StringReader et ByteArrayInputStream permettent de voir un tableau ou une chaîne comme un flot (supportant mark) Les classes CharArrayWriter, StringWriter et ByteArrayOutputStream permettent d'écrire dans un tableau avec un mécanisme de flux ; la taille du tableau est augmentée quand nécessaire ;
19 Flots d une chaîne On récupère le tableau avec tochararray ou tobytearray. Pour CharArrayWriter et StringWriter, la méthode tostring renvoie la chaîne correspondante à ce qui a été écrit ; pour StringWriter, la méthode getbuffer retourne l objet StringBuffer associé.
20 Tubes Les classes PipedInputStream/OS, PipedReader/Writer permettent d avoir des flux «tubes» : un tube en entrée est connecté à un tube en sortie de même type (octets ou caractères) ; les données écrites dans l entrée du tube (Writer ou OutputStream) peuvent être lues dans la sortie du tube (Reader ou InputStream).
21 Tubes Les tubes peuvent être utilisés comme moyen de communication entre Thread (processus légers) ; il est déconseillé de les utiliser dans un même Thread (risque de blocage). quand l un des Thread communiquant meurt, la lecture ou l écriture sur l autre côté du tube provoque une IOException. on préférera utiliser les collections bloquantes
22 Filtres En plus des flots concrets, il existe des flots appelés «filtres», qui ajoutent des fonctionnalités aux flots existants ; ces flots ont un constructeur prenant un flot qui sera utilisé pour les opérations d écriture «bas niveau», et fournissent des opérations d écritures «haut niveau» (comme par exemple printf par rapport à write).
23 Codage de caractères Les classes InputStreamReader et OutputStreamWriter permettent de transformer un flot d'octets en flot de caractères ; soit on spécifie un codage de caractères ; soit est pris celui par défaut du système, éventuellement différent pour chaque système ; quand on écrit un protocole réseau, il faut choisir un codage de caractères.
24 Codage de caractères On spécifie un codage par son nom, un objet Charset ou un objet CharsetDecoder du paquetage java.nio.charset ; les codages disponibles sont donnés par java.nio.charset.charset.availablecharsets() ; tous les flots qui transforment mal des octets en caractères sont dépréciés (comme StringBufferInputStream) on peut aussi utiliser les nio!
25 Flots bufferisés Les classes BufferedInputStream/OS BufferedReader/Writer ajoutent une bufferisation au flot ; cela permet de lire ou écrire caractère par caractère de manière efficace ; la classe BufferedReader permet de lire ligne par ligne avec la méthode readline ;
26 Numéro de ligne La classe LineNumberReader maintient en plus un numéro de ligne (la méthode setlinenumber ne change pas la position dans le flot) ; la classe LineNumberInputStream est dépréciée car n a pas de gestion correcte des codages de caractères.
27 Flots d affichage La classe PrintWriter permet d afficher la représentation de n importe quelle valeur, de type primitif ou objet avec les méthodes print ou println ; la méthode println ajoute un retour-chariot à la fin mais pas print ; pour les objets, la méthode tostring est appelée.
28 Flots d affichage La classe PrintStream effectue la même chose que la classe PrintWriter, soit en convertissant avec le codage par défaut, soit en utilisant celui donné à la construction ; la méthode println ajoute un retour-chariot à la fin mais pas print ; pour les objets, la méthode tostring est appelée.
29 Flots d affichage Les méthodes de la classe PrintWriter et PrintStream ne lancent pas IOException ; on utilise checkerror pour savoir s'il y a eu une erreur (on ne peut pas savoir laquelle) ; par défaut, les données ne sont pas «flushed» automatiquement ; avec l argument de constructeur autoflush à true, une écriture d un buffer ou d un \n provoque le flush du flot.
30 Flots d'affichage Les deux classes disposent d'une méthode printf (merci l'autoboxing et le variadique) Ce service est délégué à la classe java.util.formatter sprintf est la méthode String.format le format est similaire (mais bien plus riche...) à celui de la libc, avec %n pour le retour chariot (dépendant de la plateforme)
31 Flots «Pushback» Les flots PushbackInputStream et PushbackReader permettent de remettre des caractères ou octets, lus ou non, dans le flot pour les lire à nouveau ; on remet des caractères avec unread ; ceci est réalisé avec un buffer fini, dont la méthode unread lance un IOException quand le buffer est plein ; on ne s'en sert pas souvent, et en plus la doc est fausse...
32 Flot séquentiel La classe SequenceInputStream prend un ensemble d'inputstream, et émule la concaténation de ces flots : il retourne d'abord les octets du premier jusqu'à la fin ; puis les octets des flots suivants, jusqu'à arriver à la fin du dernier flot.
33 Flots de données Les flots DataInputStream et DataOutputStream servent à écrire ou lire des données d une manière indépendante du système ; l'exception EOFException est lancée à la fin du flot ; la méthode readfully permet de bloquer jusqu à ce que soient lues le nombre d octets demandés les spécifications des méthodes sont données par les interfaces DataInput et DataOutput
34 Exemple public void writenamedpoint(dataoutputstream out, NamedPoint p) throws IOException { out.writeint(p.x); out.writeint(p.y); out.writeutf(p.name); } public NamedPoint readnamedpoint (DataOutputStream in) throws IOException { int x = in.readint(); int y = in.readint(); String name = in.readutf(); return new NamedPoint(name,x,y); }
35 Accès aux fichiers On peut lire et écrire dans un fichier avec la classe RandomAccessFile ; On peut spécifier différents modes : "r" lecture seule ; "rw" lecture et écriture, avec création du fichier ; "rwd" comme "rw", mais synchronisé avec le système de fichiers (sauf réseau) ; "rws" comme "rwd", mais les statistiques du fichier sont aussi synchronisées
36 Accès aux fichiers On se déplace dans le fichier avec la méthode seek ; on accède à la position courante avec getfilepointer ; on obtient la longueur avec length, que l'on change avec setlength ; on le ferme avec close ; On peut écrire et lire des données comme dans DataInputStream et DataOutputStream ; on ne peut pas spécifier de codage de caractères les spécifications des méthodes sont données par les interfaces DataInput et DataOutput
37 Flots d objets Les flots ObjectInputStream et ObjectOutputStream permettent de stocker et restaurer des objets ; EOFException est lancée à la fin du flot ; le système inclus un système de version de classe ; les objets écrits dans les flots doivent implémenter l interface marqueur Serializable ; bien sûr, Object n est pas sérialisable.
38 Flots d objets Lors du stockage d un objet, la machine virtuelle recherche tous les objets dépendants et les stocke aussi, en repérant les boucles ; seuls les attributs de la classe et des superclasses sérialisables sont stockés dans le flot, sauf s ils sont marqués transient ; ces attributs doivent être eux-mêmes sérialisable ou l exception NotSerializableException est levée.
39 Flots d objets Lors de la restauration d un objet, l'initialisation des champs se fait comme avec un constructeur : de Object à la classe ; le constructeurs sans paramètres de la première superclasse non sérialisable est appelé, et leurs champs sont initialisés par ce dernier, et ne reprennent donc pas leur ancienne valeur ; l exception InvalidClassException est levée s il n existe pas ; les champs non transient des superclasses sérialisables et de la classe sont restaurés, sans appel à un constructeur, les autres initialisés à leur valeur par défaut (0, null, false)
40 public class A { int x,y; public A() { this(3,3); } public A(int x,int y) { this.x=x; this.y=y; } } public class B extends A implements Serializable { transient int z = 8; int a; } B b = new B(); b.x=10;b.y=11;b.z=12;b.a=13; out.writeobject(b); out.close(); Exemple B b = (B)in.readObject(); System.out.printf("x=%d y=%d z=%d a=%d%n",b.x,b.y,b.z,b.a); in.close(); x=3 y=3 z=0 a=13
41 Flots d objets La sérialisation permet aussi de transmettre des objets via le réseau, ou à une autre application java (drag and drop, copier/coller) On peut ajouter des méthodes éventuellement privées à une classe, readobject(objectinputstream) et writeobject(objectoutputstream) pour mieux contrôler la sauvegarde et la restauration Elle seront appelées à la place du mécanisme par défaut
42 Créations de nouveaux flots Les classes abstraites InputStream, OutputStream, Reader et Writer permettent de créer facilement de nouveaux flots ; les classes FilterInputStream, FilterOutputStream et les classes abstraites FilterReader et FilterWriter permettent de créer de nouveaux filtres.
Entrées / Sorties. Entrées / Sorties. Entrées/Sorties. System.out. Fonctionnement par flots (stream) Karima Boudaoud IUT- R&T. Terrain connu.
Entrées / Sorties Entrées/Sorties Fonctionnement par flots (stream) Karima Boudaoud IUT- R&T Karima Boudaoud IUT GTR-Sophia Antipolis 2 Terrain connu Entrées / Sorties la classe java.lang.system cette
Plus en détailFlux de données Lecture/Ecriture Fichiers
Flux de données Lecture/Ecriture Fichiers 1 Un flux de données est un objet qui représente une suite d octets d un programme pour une certaine destination ou issus d une source pour un programme flux d
Plus en détailCours 14 Les fichiers
Cours 14 Les fichiers F. Gayral 1 Fichier : définition /media/travaux/documents/fgenseignement/java1/courstpsfgfc/14-fichiers/voirtypefichiers Fichier = ensemble d informations codées et stockées sur une
Plus en détailProgrammation Orientée Objet - Licence TIS CM8/9. Rappel sur la séance précédente. Lancelot Pecquet Lancelot.Pecquet@math.univ-poitiers.
Programmation Orientée Objet - Licence TIS CM8/9 Lancelot Pecquet Lancelot.Pecquet@math.univ-poitiers.fr Poitiers, le 13/03/2006 Rappel sur la séance précédente La fois précédente, nous avons vu : 1 UML
Plus en détailPour plus de détails concernant le protocole TCP conférez vous à la présentation des protocoles Internet enseignée pendant.
Chapitre 7 Le mode de communication en connexion est, a priori, supporté par le protocole TCP. Ce protocole fournit une communication fiable; les données sont transmises comme chaînes d octets. Avant de
Plus en détailDéveloppement Logiciel
Développement Logiciel Éxamen session 1-2012-2013 (Vendedi 25 mai, 9h-11h) Seuls les documents liés directement au cours sont autorisés (comme dit sur le site) : sujets de TD, notes de cours, notes personnelles
Plus en détailPROGRAMMATION 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étailExceptions. 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étailEnvironnements de développement (intégrés)
Environnements de développement (intégrés) Tests unitaires, outils de couverture de code Patrick Labatut labatut@di.ens.fr http://www.di.ens.fr/~labatut/ Département d informatique École normale supérieure
Plus en détailProgrammation Internet en Java
Chapitre 8 Programmation Internet en Java Vous avez déjà utilisé Internet, le plus connu des inter-réseaux mondiaux d ordinateurs et quelques-uns de ses services, en particulier le web et le courrier électronique.
Plus en détailProgrammer 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étailIntroduction à 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étailExclusion 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étailGestion 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étailLes chaînes de caractères
Les chaînes de caractères Dans un programme informatique, les chaînes de caractères servent à stocker les informations non numériques comme par exemple une liste de nom de personne ou des adresses. Il
Plus en détailCertificat Big Data - Master MAthématiques
1 / 1 Certificat Big Data - Master MAthématiques Master 2 Auteur : Sylvain Lamprier UPMC Fouille de données et Medias Sociaux 2 / 1 Rich and big data: Millions d utilisateurs Millions de contenus Multimedia
Plus en détailProjet 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étailTravaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation
Université de Savoie Module ETRS711 Travaux pratiques Compression en codage de Huffman 1. Organisation du projet 1.1. Objectifs Le but de ce projet est d'écrire un programme permettant de compresser des
Plus en détailProgrammation système de commandes en C
Programmation système de commandes en C Cours de Programmation système Tuyêt Trâm DANG NGOC Université de Cergy-Pontoise 2012 2013 Tuyêt Trâm DANG NGOC Programmation système de commandes
Plus en détailLicence 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étailTP 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étail1 Lecture de fichiers
Programmation 1 Cours n 6 GB3, 2 nd semestre 2014-2015 Cours de Python Gilles Bernot 1 Lecture de fichiers Un fichier est une suite de caractères mémorisés sur le disque dur de la machine dans un endroit
Plus en détailProgrammation 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étailCours de Système : Gestion de Fichiers
Cours de Système : Gestion de Fichiers Bertrand Le cun et Emmanuel Hyon bertrand.le cun{at}u-paris10.fr et Emmanuel.Hyon{at}u-paris10.fr Université Paris Ouest Nanterre 25 octobre 2011 B.L.C. & E.H. (UPO)
Plus en détailDans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers.
I Présentation : Dans le chapitre 1, nous avons vu comment utiliser les appels-systèmes de bas niveau pour créer et accéder à des fichiers sur le disque. Nous avons notamment mis en évidence leur dépouillement
Plus en détailPlan 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étailGESTION DES FICHIERS C/UNIX
Licence IG Page 1 sur 6 GESTION DES FICHIERS C/UNIX Introduction Deux modes d appel - Par la bibliothèque standard C (appel de haut niveau) - Par appels système (bas niveau) Nécessite les includes suivant
Plus en détailTP1. Outils Java Eléments de correction
c sep. 2008, v2.1 Java TP1. Outils Java Eléments de correction Sébastien Jean Le but de ce TP, sur une séance, est de se familiariser avec les outils de développement et de documentation Java fournis par
Plus en détailJava 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étailCours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java
Langages objets Introduction M2 Pro CCI, Informatique Emmanuel Waller, LRI, Orsay présentation du module logistique 12 blocs de 4h + 1 bloc 2h = 50h 1h15 cours, 45mn exercices table, 2h TD machine page
Plus en détailBases 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étailPremiers 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étailProgrammation client-serveur sockets - RPC
Master Informatique M Plan de la suite Programmation client-serveur sockets - RPC Sacha Krakowiak Université Joseph Fourier Projet Sardes (INRIA et IMAG-LSR) http://sardes.inrialpes.fr/people/krakowia
Plus en détailProgrammation impérative
Programmation impérative Cours 4 : Manipulation des fichiers en C Catalin Dima Organisation des fichiers Qqs caractéristiques des fichiers : Nom (+ extension). Chemin d accès absolu = suite des noms des
Plus en détailAuto-é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étailRemote 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étailRMI 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étailCours 6 : Tubes anonymes et nommés
Cours 6 : Tubes anonymes et nommés Mécanisme de communications du système de fichiers I-node associé. Type de fichier: S_IFIFO. Accès au travers des primitives read et write. Les tubes sont unidirectionnels
Plus en détailJ2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation
J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation Cycle Ingénierie 2e année SIGL Dernière mise à jour : 19/10/2006 Christophe Porteneuve Threads Principes Cycle de vie Création java.lang.thread
Plus en détailTD3: 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étailTP : Gestion d une image au format PGM
TP : Gestion d une image au format PGM Objectif : L objectif du sujet est de créer une classe de manipulation d images au format PGM (Portable GreyMap), et de programmer des opérations relativement simples
Plus en détailINTRODUCTION 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étailJava 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étailCours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
Plus en détailIntroduction à la Programmation Parallèle: MPI
Introduction à la Programmation Parallèle: MPI Frédéric Gava et Gaétan Hains L.A.C.L Laboratoire d Algorithmique, Complexité et Logique Cours du M2 SSI option PSSR Plan 1 Modèle de programmation 2 3 4
Plus en détailPolymorphisme, 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étailCours 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étailet se trouve popularisé rapidement pour ses possibilités de développement liés au Web. Les
Chapitre 3 Java, langage de développement objet 3.1 Présentation de Java 3.1.1 Objectifs Le langage Java a été développé afin de pouvoir générer des applications qui soient indépendantes des machines et
Plus en détailCours d introduction à l informatique. Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions
Cours d introduction à l informatique Partie 2 : Comment écrire un algorithme? Qu est-ce qu une variable? Expressions et instructions Qu est-ce qu un Une recette de cuisine algorithme? Protocole expérimental
Plus en détailINITIATION AU LANGAGE JAVA
INITIATION AU LANGAGE JAVA I. Présentation 1.1 Historique : Au début des années 90, Sun travaillait sur un projet visant à concevoir des logiciels simples et performants exécutés dans des PDA (Personnal
Plus en détailTP1 : 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étailTravaux Pratiques : Lucène - Gestion d un index plein texte
Chapter 1 Travaux Pratiques : Lucène - Gestion d un index plein texte Pour ce TP, nous allons étudier l utilisation d un index de recherche textuel OpenSource : Lucene 1. Nous allons créer un projet en
Plus en détailProgrammation Réseau SSH et TLS (aka SSL)
Programmation Réseau SSH et TLS (aka SSL) Jean-Baptiste.Yunes@liafa.jussieu.fr Coloriages: François Armand armand@informatique.univ-paris-diderot.fr UFR Informatique 2011-2012 Réseau et Sécurité Problèmes
Plus en détailJava 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étailCentre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :
Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de
Plus en détailCommunication inter-processus (IPC) : tubes & sockets. exemples en C et en Java. F. Butelle
F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Communication inter-processus (IPC) : tubes & sockets exemples en C et en Java F. Butelle F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Java : implémentation
Plus en détailTP Composants Java ME - Java EE. Le serveur GereCompteBancaireServlet
TP Composants Java ME - Java EE Vous allez, dans ce TP, construire une architecture client serveur, plus précisément MIDlet cliente, servlet serveur. Pour cela, on va d'abord installer la partie serveur
Plus en détailProgrammation 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étailPour 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étailCours de Systèmes d Exploitation
Licence d informatique Synchronisation et Communication inter-processus Hafid Bourzoufi Université de Valenciennes - ISTV Introduction Les processus concurrents s exécutant dans le système d exploitation
Plus en détailUn 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étailBases de programmation. Cours 5. Structurer les données
Bases de programmation. Cours 5. Structurer les données Pierre Boudes 1 er décembre 2014 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. Types char et
Plus en détailIntroduction : les processus. Introduction : les threads. Plan
IN328 Programmation distribuée avec Java et J2EE 2 - Threads en Java Introduction : les processus Un processus est un ensemble d instructions à exécuter, un espace mémoire réservé et éventuellement d autres
Plus en détailTP, première séquence d exercices.
TP, première séquence d exercices. Benoît Valiron benoit.valiron@lipn.univ-paris13.fr 7 novembre 2010 Introduction Vous écrirez les réponses aux questions courtes sur une feuille à rendre à la fin de la
Plus en détailGénie Logiciel I. Cours VI - Typage statique / dynamique, fonctions virtuelles et classes abstraites, flots d entrées / sorties, et string
Génie Logiciel I Cours VI - Typage statique / dynamique, fonctions virtuelles et classes abstraites, flots d entrées / sorties, et string Nicolas Kielbasiewicz C.D.C.S.P./I.S.T.I.L./I.C.J. Filière M.A.M.
Plus en détailPROJET ALGORITHMIQUE ET PROGRAMMATION II
PROJET 1 ALGORITHMIQUE ET PROGRAMMATION II CONTENU DU RAPPORT A RENDRE : o Fiche signalétique du binôme o Listing des différents fichiers sources o CD sources o Il sera tenu compte de la présentation du
Plus en détailLangage 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étailConventions d écriture et outils de mise au point
Logiciel de base Première année par alternance Responsable : Christophe Rippert Christophe.Rippert@Grenoble-INP.fr Introduction Conventions d écriture et outils de mise au point On va utiliser dans cette
Plus en détailCorrigé 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étailCours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples
Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation impérative et structures de données simples Introduction au langage C Sandrine Blazy - 1ère année 24 octobre 2007 Cours d Algorithmique-Programmation
Plus en détailLambda! 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étailProgrammation système I Les entrées/sorties
Programmation système I Les entrées/sorties DUT 1 re année Université de Marne La vallée Les entrées-sorties : E/O Entrées/Sorties : Opérations d échanges d informations dans un système informatique. Les
Plus en détail1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.
1. Structure d un programme C Un programme est un ensemble de fonctions. La fonction "main" constitue le point d entrée pour l exécution. Un exemple simple : #include int main() { printf ( this
Plus en détailCahier des Charges du Projet Domotique. Choquet Mathieu Masson Jérôme Groupe 6. Domotique. p.1
Choquet Mathieu Masson Jérôme Groupe 6 Domotique p.1 SOMMAIRE : Introduction...... I/ Envoi de SMS...... II/ Architecture...... III/ Serveur...... IV/ Détection de mouvement...... V/ Problème rencontré......
Plus en détailTable des matières PRESENTATION DU LANGAGE DS2 ET DE SES APPLICATIONS. Introduction
PRESENTATION DU LANGAGE DS2 ET DE SES APPLICATIONS Depuis SAS 9.2 TS2M3, SAS propose un nouveau langage de programmation permettant de créer et gérer des tables SAS : le DS2 («Data Step 2»). Ces nouveautés
Plus en détailRMI. Remote Method Invocation: permet d'invoquer des méthodes d'objets distants.
RMI Remote Method Invocation: permet d'invoquer des méthodes d'objets distants. Méthode proche de RPC. Outils et classes qui rendent l'implantation d'appels de méthodes d'objets distants aussi simples
Plus en détailTp 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étailAlgorithmique et Programmation, IMA
Algorithmique et Programmation, IMA Cours 2 : C Premier Niveau / Algorithmique Université Lille 1 - Polytech Lille Notations, identificateurs Variables et Types de base Expressions Constantes Instructions
Plus en détailSEMIN. Données sous R : stockage et échange. Julio PEDRAZA ACOSTA
SEMIN Données sous R : stockage et échange Julio PEDRAZA ACOSTA UMR 5202 Origine Structure et Evolution de la Biodiversité Département Systématique et Evolution, MNHN pedraza@mnhn.fr SEMIN R du MNHN 10
Plus en détailPrésentation du langage et premières fonctions
1 Présentation de l interface logicielle Si les langages de haut niveau sont nombreux, nous allons travaillé cette année avec le langage Python, un langage de programmation très en vue sur internet en
Plus en détailSeance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu.
Seance 2: Complétion du code de jeu. (durée max: 2h) Mot clé const et pointeurs: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Implémentez jeu_recupere_piece
Plus en détailCours d initiation à la programmation en C++ Johann Cuenin
Cours d initiation à la programmation en C++ Johann Cuenin 11 octobre 2014 2 Table des matières 1 Introduction 5 2 Bases de la programmation en C++ 7 3 Les types composés 9 3.1 Les tableaux.............................
Plus en détailChapitre 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étailProgrammation 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étailUtilisation 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étailProjet gestion d'objets dupliqués
Projet gestion d'objets dupliqués Daniel Hagimont Daniel.Hagimont@enseeiht.fr 1 Projet Service de gestion d'objets dupliqués Mise en cohérence lors de la prise d'un verrou sur un objet Pas de verrous imbriqués
Plus en détailLes fichiers. Chapitre 4
Chapitre 4 Les fichiers Jusqu à maintenant tous les programmes que nous avons conçus travaillaient sur des données qui étaient perdues après chaque session de travail. On peut cependant, c est bien naturel,
Plus en détailACTIVITÉ DE PROGRAMMATION
ACTIVITÉ DE PROGRAMMATION The purpose of the Implementation Process is to realize a specified system element. ISO/IEC 12207 Sébastien Adam Une introduction 2 Introduction Ø Contenu Utilité de l ordinateur,
Plus en détailSynchro et Threads Java TM
Synchro et Threads Java TM NICOD JEAN-MARC Master 2 Informatique Université de Franche-Comté UFR des Sciences et Techniques septembre 2008 NICOD JEAN-MARC Synchro et Threads avec Java TM 1 / 32 Sommaire
Plus en détailEPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE QCM Remarque : - A une question correspond au moins 1 réponse juste - Cocher la ou les bonnes réponses Barème : - Une bonne réponse = +1 - Pas de réponse = 0
Plus en détailGénie Logiciel avec Ada. 4 février 2013
Génie Logiciel 4 février 2013 Plan I. Généralités II. Structures linéaires III. Exceptions IV. Structures arborescentes V. Dictionnaires I. Principes II. Notions propres à la POO I. Principes Chapitre
Plus en détailChap III : Les tableaux
Chap III : Les tableaux Dans cette partie, on va étudier quelques structures de données de base tels que : Les tableaux (vecteur et matrice) Les chaînes de caractères LA STRUCTURE DE TABLEAU Introduction
Plus en détailSTAGE IREM 0- Premiers pas en Python
Université de Bordeaux 16-18 Février 2014/2015 STAGE IREM 0- Premiers pas en Python IREM de Bordeaux Affectation et expressions Le langage python permet tout d abord de faire des calculs. On peut évaluer
Plus en détailApproche Contract First
Exemple HelpDesk Approche Contract First Développement d un premier web service en utilisant l approche contract first (ou WSDL First) Écriture du wsdl avant d écrire le code java Autre possibilité implementation
Plus en détailIntroduction au langage C
Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les
Plus en détailINITIATION AU LANGAGE C SUR PIC DE MICROSHIP
COURS PROGRAMMATION INITIATION AU LANGAGE C SUR MICROCONTROLEUR PIC page 1 / 7 INITIATION AU LANGAGE C SUR PIC DE MICROSHIP I. Historique du langage C 1972 : naissance du C dans les laboratoires BELL par
Plus en détail6 - Le système de gestion de fichiers F. Boyer, UJF-Laboratoire Lig, Fabienne.Boyer@imag.fr
6 - Le système de gestion de fichiers F. Boyer, UJF-Laboratoire Lig, Fabienne.Boyer@imag.fr Interface d un SGF Implémentation d un SGF Gestion de la correspondance entre la structure logique et la structure
Plus en détailLes processus légers : threads. Système L3, 2014-2015 1/31
Les processus légers : threads Système L3, 2014-2015 1/31 Les threads Les threads sont des processus légers exécutés à l intérieur d un processus L exécution des threads est concurrente Il existe toujours
Plus en détailNFP 121. Java et les Threads. Présentation : Thierry Escalarasse Mai 2007
NFP 121 Java et les Threads Présentation : Thierry Escalarasse Mai 2007 Plan du cour Présentation de la notion de Threads La classe Thread L interface Runnable Les états d un thread La Synchronisation
Plus en détailSYSTÈME DE GESTION DE FICHIERS
SYSTÈME DE GESTION DE FICHIERS - DISQUE 1 Les couches logiciels réponse requête Requêtes E/S Système E/S Pilote E/S Interruptions utilisateur traitement S.E. commandes S.E. S.E. matériel Contrôleur E/S
Plus en détail