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

Entrée/Sortie Java Discussion :

JNI et C++ problème de décalage dans les I/O


Sujet :

Entrée/Sortie Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Novembre 2012
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Ingénieur de Recherche

    Informations forums :
    Inscription : Novembre 2012
    Messages : 8
    Par défaut JNI et C++ problème de décalage dans les I/O
    Bonjour,

    Dans mon code, j'ai une boucle qui fait appel à une librairie C++ interfacé via JNI.

    Les fonctions en jni en plus d'une série de calcul sont sensées envoyer des informations sur la sortie standard et écrire dans des fichiers qui seront relus ultérieurement avant la fin de l'exécution du code java.

    Le code java récupère correctement les valeurs de sortie (des types primitifs) de ces fonctions lors de l’exécution. Mais les sorties à l'écran se font après clôture du java et il semble que se soit la même chose pour l'écriture des fichiers (fichier vide avant la fin de l’exécution).

    Auriez vous des suggestions pour me débloquer?

    Par avance merci de votre aide,

  2. #2
    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,


    Qui a fait cette librairie native ?
    As-tu accès au code natif ? Les flux sont-ils bien flushé/fermé ?


    a++

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Novembre 2012
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Ingénieur de Recherche

    Informations forums :
    Inscription : Novembre 2012
    Messages : 8
    Par défaut
    J'ai transcris cette librairie native d'un C fait en C++ en C++.

    Les I/O sont sortis via printf ou fprinf comme dans le code d'origine.

    J'ouvre et je ferme les fichiers à chaque appel de la boucle via jni avec fopen et fclose. J'affiche "ouverture ok" et "fermer of" à chaque fois.

    A l'affichage j'obtiens :

    "Je Passe 1" correspond à l’initialisation.
    "Arret de l'IMR" à l'arret du code java.

    Arret de l'IMR.
    ouverture ok Durée : 50
    Age Maturité Pointe : 6.50000
    Vitesse d'emission des primaires : 0.42185
    Nombre maximal de primaires : 1
    Diamètre minimal : 0.08600
    Diamètre maximal : 0.42500
    Pente vitesse de croissance diamètre : 11.66365
    Type de tropisme : 1
    Intensité du tropisme : 0.03000
    Distance inter-ramifications : 3.91400
    Pente de la relation entre diamètre des latérales : 0.23362
    Coefficient de variabilité des latérales : 0.24828
    Masse volumique des racines : 0.07176
    Pente durée de vie : 80000.00000
    Coefficient de croissance radiale : 0.50000
    Je passe 1 fermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okferme

  4. #4
    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
    Citation Envoyé par francois.cheminade Voir le message
    Les I/O sont sortis via printf ou fprinf comme dans le code d'origine.
    Java et C/C++ utilisent chacun leurs propres buffers pour leurs sorties standards.
    Le "flush" peut dépendre de plusieurs critères, et comme il y a 2 buffers différents l'ordre n'est pas garantie.

    Vu le peu de données envoyé sur stdout, il y a des chances que cela ne soit flusher qu'à la fin du programme...


    Pour avoir un résultat un peu plus cohérent de l'ordre d’exécution, tu dois appeler explicitement flush() sur tes flux de sortie, à la fois dans le code Java ET dans le code C/C++.




    Pour les fichiers s'ils sont bien fermé c'est étrange...


    a++

  5. #5
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    fermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okfermer okouverture okferme
    Il n'y a pas de retour à la ligne -> C'est coincé dans le buffer de stdout.
    Rajout un \n à tes messages et ça devrais résourdre ton problème

  6. #6
    Membre averti
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Novembre 2012
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Ingénieur de Recherche

    Informations forums :
    Inscription : Novembre 2012
    Messages : 8
    Par défaut
    Merci, ça marche pour l'affichage.

    Pour l'écriture, j'avais simplement oublié d'ordonner pour le fichier dans la boucle. Les retards à l'affichage m'ont induit en erreur ailleurs.

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

Discussions similaires

  1. Problème d'espace dans les varibles passées par GET !
    Par boukay dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 07/03/2006, 14h36
  2. Problème d'affichage dans les textbox
    Par popinenhbourg dans le forum Servlets/JSP
    Réponses: 8
    Dernier message: 28/02/2006, 12h09
  3. Problème d'affichage dans les textbox
    Par popinenhbourg dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 28/02/2006, 11h36
  4. [VB.NET] [Débutant] Probléme de variable dans les requettes
    Par Silvia12 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 07/03/2005, 13h13
  5. Réponses: 14
    Dernier message: 01/09/2003, 22h46

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