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

Java Discussion :

Cache et Multithreading


Sujet :

Java

  1. #21
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Salut,

    A mon avis, les 2 premiers "niveaux" de splitCcPairSymbo ne servent à rien : les supprimer permettrait de gagner un peu de cpu (un peu de traitement de pile, et gain sur les trucs faits en double).

    Je remplacerais la termMapByString, map étant fixe visiblement, par un switch. Aussi fastidieux à écrire, mais probablement un peu plus lisible en plus. Tu peux faire une moulinette pour la conversion si tu ne veux pas tout te retaper.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  2. #22
    Membre Expert
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Par défaut
    Deja, tu n'utilises pas map.putIfAbsent. A mon avis, ce serait mieux pour s'assurer que c'est toujours le meme objet cpair qui est utilisé. Je sais que tu as deja dit que ce n'etait pas grave pour toi mais c'est contre intuitif quand on crée un cache d'utiliser des objets qui ne viennent pas du cache. Si demain, quelqu'un d'autre touche a ton code, il va peut etre vouloir mettre une instru dans l'objet CCPair et ne s'attendra pas à ce que des objets qui ne sont pas cachés soient utilisés.

    Citation Envoyé par Yonito Voir le message
    1. De ce que j'ai compris du post, un split sur un char n'utilise pas de regex ?
    Vu la simplicité de ce que tu fais, en supposant que ca a reellement un impact sur ton fonctionnement, je partirais plutot sur un parsing de la string à la main. Une regex a besoin d'etre compilée et interprétée. C'est puissant pour des traitements relativement complexes mais dans ton cas, ca me parait etre la grosse artillerie pour pas grand chose. Une petite boucle de quelques millions de tests te permettra de voir si ca t'apporte quelque chose ou non.

    Citation Envoyé par Yonito Voir le message
    2. En allant voir le code de get() pour une concurrentHashMap je n'ai pas vu de synchronize contrairement au put(). Etes vous sur que le get est egalement synchronize comme dit plus haut ?
    C'est justement l'interet d'utiliser une concurrentHashMap. Seul le put est synchronisé (voir la javadoc). Le get n'est synchronisé que si l'item est en cours d'insertion.

  3. #23
    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 hwoarang Voir le message
    Vu la simplicité de ce que tu fais, en supposant que ca a reellement un impact sur ton fonctionnement, je partirais plutot sur un parsing de la string à la main. Une regex a besoin d'etre compilée et interprétée. C'est puissant pour des traitements relativement complexes mais dans ton cas, ca me parait etre la grosse artillerie pour pas grand chose. Une petite boucle de quelques millions de tests te permettra de voir si ca t'apporte quelque chose ou non.
    Pas forcément : le split() de la classe String n'utilise pas les regexp lorsqu'on lui passe un séparateur d'une seule lettre...

    Par contre oui dans ce cas précis comme on fait déjà des indexOf() autant faire directement un substring() derrière.



    Citation Envoyé par Yonito Voir le message
    2. En allant voir le code de get() pour une concurrentHashMap je n'ai pas vu de synchronize contrairement au put(). Etes vous sur que le get est egalement synchronize comme dit plus haut ?
    Parce qu'un code thread-safe ne passe pas forcément par de la synchronisation, notamment pour la lecture.
    En travaillant avec des données volatile et/ou des opérations atomiques, on peut très bien faire un code thread-safe sans forcément avoir besoin de bloc synchronized.




    Sinon deux petites remarques sur ton code :

    • "termMapByString" et "termMapByFixTenor" sont deux Map static non-threadsafe.
      Cela ne pose pas de problème puisque tu ne les modifies pas après-coup, pour l'instant...
      Si un jour quelqu'un s'amuse à modifier ces Map après l'initialisation de la classe, tu pourrais te retrouver avec des erreurs difficiles à comprendre.

      Je te conseille de les englober dans une "unmodifiableMap".
      Perso dans ce cas j'utilise le pattern suivant :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      	private static final Map<String, Term> termMapByString = createTermMapByString();
       
      	private static Map<String, Term> createTermMapByString() {
      		Map<String, Term> map = new HashMap<>();
      		// map.put(...);
      		return Collections.unmodifiableMap(map);
      	}
      Voir si tu ne veux pas définir de méthode même private :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      	private static final Map<String, Term> termMapByString;
      	static {
      		Map<String, Term> map = new HashMap<>();
      		// map.put(...);
      		termMapByString = Collections.unmodifiableMap(map);
      	}

    • Pourquoi splitCcPairSymbol() retourne-t-il une List<String> ?
      Cela me semble un peu inutile puisque tu construis une liste pour la décomposer immédiatement et créer un CCPair.
      Autant faire en sorte que cette méthode retourne directement un CCPair, tu t'éviteras encore quelques objets temporaires...




    a++

  4. #24
    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 : 45
    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
    Citation Envoyé par Yonito Voir le message
    2. En allant voir le code de get() pour une concurrentHashMap je n'ai pas vu de synchronize contrairement au put(). Etes vous sur que le get est egalement synchronize comme dit plus haut ?
    Une erreur de ma part que hwoarang a déjà corrigée. J'ai en fait mal lu ta réponse et j'ai cru que tu utilisais Collections.synchronizedMap(). Désolé.

  5. #25
    Membre expérimenté
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2013
    Messages
    131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Israël

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2013
    Messages : 131
    Par défaut
    Citation Envoyé par adiGuba Voir le message

    Sinon deux petites remarques sur ton code :

    • "termMapByString" et "termMapByFixTenor" sont deux Map static non-threadsafe.
      Cela ne pose pas de problème puisque tu ne les modifies pas après-coup, pour l'instant...
      Si un jour quelqu'un s'amuse à modifier ces Map après l'initialisation de la classe, tu pourrais te retrouver avec des erreurs difficiles à comprendre.

      Je te conseille de les englober dans une "unmodifiableMap".
      Perso dans ce cas j'utilise le pattern suivant :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      	private static final Map<String, Term> termMapByString = createTermMapByString();
       
      	private static Map<String, Term> createTermMapByString() {
      		Map<String, Term> map = new HashMap<>();
      		// map.put(...);
      		return Collections.unmodifiableMap(map);
      	}
      Voir si tu ne veux pas définir de méthode même private :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      	private static final Map<String, Term> termMapByString;
      	static {
      		Map<String, Term> map = new HashMap<>();
      		// map.put(...);
      		termMapByString = Collections.unmodifiableMap(map);
      	}

    • Pourquoi splitCcPairSymbol() retourne-t-il une List<String> ?
      Cela me semble un peu inutile puisque tu construis une liste pour la décomposer immédiatement et créer un CCPair.
      Autant faire en sorte que cette méthode retourne directement un CCPair, tu t'éviteras encore quelques objets temporaires...




    a++

    Merci ce conseil la , je vais l'utilise dans mon code !

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Répertoire caché
    Par KUBITUS dans le forum Delphi
    Réponses: 30
    Dernier message: 13/04/2007, 07h19
  2. Qu'est ce que le cache ?
    Par irrou dans le forum Assembleur
    Réponses: 4
    Dernier message: 24/11/2002, 23h28
  3. Multithreading sous HP Ux 11
    Par pykoon dans le forum Autres éditeurs
    Réponses: 1
    Dernier message: 18/10/2002, 23h36
  4. Ouvrir (fopen) un fichier caché
    Par shef dans le forum C
    Réponses: 2
    Dernier message: 09/09/2002, 09h06
  5. Webbrowser : Comment ne pas prendre la page en cache
    Par cedm78 dans le forum Web & réseau
    Réponses: 3
    Dernier message: 30/08/2002, 11h17

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