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 :

Opérations avec Chiffres > à 10 milliards


Sujet :

Langage Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 80
    Points : 67
    Points
    67
    Par défaut Opérations avec Chiffres > à 10 milliards
    lu,

    J'aimerai savoir s'il est obligé d'utiliser les Big Decimal et Big Integer si l'on manipule des chiffres dans des opérations aboutissants à un nombre au alentour de 100 - 200 Milliards ( au maximum ) ??

    Car je dois avouer qu'ils ne sont pas très pratique à utiliser, et surtout pas lisible, pour des calculs complexes.

    Il n'y aurait pas une astuce pour que les double et long puissent convenir ?

    @+

  2. #2
    Membre expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Points : 3 080
    Points
    3 080
    Par défaut
    Citation Envoyé par aristeas
    lu,

    J'aimerai savoir s'il est obligé d'utiliser les Big Decimal et Big Integer si l'on manipule des chiffres dans des opérations aboutissants à un nombre au alentour de 100 - 200 Milliards ( au maximum ) ??

    Car je dois avouer qu'ils ne sont pas très pratique à utiliser, et surtout pas lisible, pour des calculs complexes.

    Il n'y aurait pas une astuce pour que les double et long puissent convenir ?

    @+
    Bah, long contient jusqu'à 2^63, c'est à dire 9223372036854775808, ce qui fait 9 milliards de milliards, ça devrait te suffire...

    Et double, c'est encore plus gros (mais il faut être conscient que la précision est moindre, forcément) : 2^1023 je crois, ce qui fait 9x10^307...
    ça fait 90 milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards de milliards
    (34 fois "de milliards")

    ça devrait suffire, non?

  3. #3
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par ®om
    Et double, c'est encore plus gros (mais il faut être conscient que la précision est moindre, forcément) : 2^1023 je crois, ce qui fait 9x10^307...

    ça devrait suffire, non?
    Bah, pour gerer mes comptes en banque, ca devrait suffire
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 80
    Points : 67
    Points
    67
    Par défaut Oups
    Heuu bah je ne sais plus trop quoi dire
    En effet je devrais avoir de quoi faire.

    Par contre j'en profite pour une petite question s'y rapportant :
    Comment fait on pour afficher un double sans avoir un nombre exponentiel suivi d' un E (ex : 2.0E11) mais bien l'intégralité du chiffre ??



  5. #5
    Membre expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Points : 3 080
    Points
    3 080
    Par défaut
    Citation Envoyé par aristeas
    Heuu bah je ne sais plus trop quoi dire
    En effet je devrais avoir de quoi faire.

    Par contre j'en profite pour une petite question s'y rapportant :
    Comment fait on pour afficher un double sans avoir un nombre exponentiel suivi d' un E (ex : 2.0E11) mais bien l'intégralité du chiffre ??


    Tu ne peux pas (enfin jusqu'à E15 tu devrais pouvoir, faut voir avec les formatters), tout simplement parce que les autres sont "perdus"...
    Par exemple si tu stoques 2^53 + 1, en mémoire tu n'as que 2^53 (le 1 est perdu).

    Un double ne peut avoir une précision que de 53 (52 + 1 implicite) bits.
    Un long en a 64.
    Donc si tu exécutes ce programme, tu te rends compte que tu perds une partie du nombre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        public static void main(String... args) {
            long long1 = (1L<<62) + 0x1FF;
            double d = long1;
            long long2 = (long) d;
            System.out.println(long1);
            System.out.println(long2);
        }

  6. #6
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par aristeas
    Par contre j'en profite pour une petite question s'y rapportant :
    Comment fait on pour afficher un double sans avoir un nombre exponentiel suivi d' un E (ex : 2.0E11) mais bien l'intégralité du chiffre ??
    Il suffit de formater le nombre selon ses besoins avant de l'afficher en utilisant NumberFormat, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    	double d = 2.0e11;
     
    	NumberFormat nf = NumberFormat.getNumberInstance();
     
    	System.out.println( d );
    	System.out.println( nf.format(d) );

    a++

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 80
    Points : 67
    Points
    67
    Par défaut +

  8. #8
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Depuis Java 5, pour les nostalgiques du printf(), il y a la classe java.util.Formatter:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    double d = 2.0E11;
    System.out.println( new Formatter().format("%f",d) );
     
    // ou plus simple
     
    System.out.printf("%f\n",d);
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 28/12/2011, 14h56
  2. Réponses: 1
    Dernier message: 07/05/2007, 20h12
  3. [VBA-E] probleme avec chiffre stocké en texte
    Par moimemessssssssss dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 25/02/2007, 19h47
  4. Réponses: 3
    Dernier message: 27/01/2007, 17h53
  5. Rand avec chiffre à virgule
    Par Mikiman dans le forum Langage
    Réponses: 2
    Dernier message: 23/09/2006, 14h56

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