IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage Java Discussion :

Try catch finally, flux best practice


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    333
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 333
    Par défaut Try catch finally, flux best practice
    Bonjour à tous,

    Mon problème est le suivant : j'ai deux flux +du code métier générant une exception, qqchose comme ça :


    1 - création flux 1
    2 - création flux 2
    3 - code métier générant une "ApplicationException"
    4 - fermeture flux 1
    5 - fermeture flux 2


    Comment est ce que je peux faire pour fermer ça proprement sans faire d'imbrication de try catch finally ??

    Passer par une sous méthode?

    un peu de code pour illustrer :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    public class AEAE {
     
    	/**
             * @param args
             * @throws Exception 
             */
     
    	public static void main(String[] args) throws Exception {
    		// TODO Auto-generated method stub
     
     
    		System.out.println(1);
    		try {
    			System.out.println(2);
    			ex();
    			System.out.println(3);
    		} catch (Exception e) {
    			System.out.println(4);
    		} finally {
    			System.out.println(5);
    			close();
    			System.out.println(5.1);
    			close();
    			System.out.println(5.2);
    		}
     
    		System.out.println(6);
     
    	}
     
     
    	public static String ex() throws Exception{
    		throw new RuntimeException();
    	}
    	public static String close() throws Exception{
    		throw new RuntimeException();
    	}
    }

    res :
    1
    2
    4
    5
    Exception in thread "main" java.lang.RuntimeException
    at AEAE.close(AEAE.java:37)
    at AEAE.main(AEAE.java:22)
    Puis je avoir 5.1 et 5.2 sans rajouter de try?

    merci

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    71
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 71
    Par défaut
    Qu'est-ce qui te pose problème dans le fait de faire un try {...} finally {...} ?

    Point important, tu n'as pas besoin de mettre un bloc catch:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    try {
        stream.open();
        callBusinessCode(stream);
    } finally {
        stream.close();
    }
    Le comportement sera que, en cas d'exception dans le bloc try, le contexte de l'exception sera sauvegardé et le branchement sera fait dans le bloc finally qui sera exécuté. Ensuite, le contexte de l'exception sera réutilisé pour relancer l'exception.

    Est-ce que ça ne résoudrait pas ton dilemme ?

  3. #3
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    A mon avis le plus simple et le plus sûr est d'utiliser un try/finally par flux, et éventuellement un try/catch global pour la gestion des exceptions...

    Quelque chose comme cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    	try {
    		InputStream in = new FileInputStream("in");
    		try {
    			OutputStream out = new FileOutputStream("out");
    			try {
    				// TRAITEMENTS
    			} finally {
    				out.close();
    			}
    		} finally {
    			in.close();
    		}
    	} catch (IOException e) {
    		e.printStackTrace();
    	}

    Par contre Yomhgui, le try/finally s'ouvre après l'ouverture du flux et non pas avant




    a++

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    71
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 71
    Par défaut
    Tu as absolument raison. J'ai tapé un peu vite !!!

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    333
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 333
    Par défaut
    Effectivement je n'avais pas pensé à imbriquer les finally de cette façon :p

    Merci pour la réponse

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

Discussions similaires

  1. Try Catch Finally et Return
    Par melleb dans le forum C#
    Réponses: 21
    Dernier message: 28/07/2011, 12h30
  2. try catch finally
    Par Javamar dans le forum Débuter avec Java
    Réponses: 7
    Dernier message: 07/03/2009, 17h05
  3. Interrogation sur : Try.Catch.Finally
    Par Seth77 dans le forum C#
    Réponses: 7
    Dernier message: 16/09/2008, 11h22
  4. Réponses: 3
    Dernier message: 12/12/2006, 18h58
  5. Réponses: 13
    Dernier message: 03/08/2006, 16h31

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo