Java.lang.Number-Klasse in Java

Java.lang.Number-Klasse in Java

Die meiste Zeit verwenden wir bei der Arbeit mit Zahlen in Java primitive Datentypen . Aber Java bietet auch verschiedene numerische Verpackung Unterklassen unter der abstrakten Klasse Number vorhanden in java.lang Paket. Es gibt hauptsächlich sechs Unterklassen unter der Zahlenklasse. Diese Unterklassen definieren einige nützliche Methoden, die beim Umgang mit Zahlen häufig verwendet werden.
 

Objekte-NummerHierarchie


Diese Klassen „verpacken“ den primitiven Datentyp in ein entsprechendes Objekt. Oft wird das Umschließen vom Compiler durchgeführt. Wenn Sie ein Grundelement verwenden, bei dem ein Objekt erwartet wird, packt der Compiler das Grundelement für Sie in seine Wrapper-Klasse. Wenn Sie ein Number-Objekt verwenden und ein Grundelement erwartet wird, entpackt der Compiler das Objekt entsprechend für Sie. Dies wird auch Autoboxing und Unboxing genannt.
Warum sollte ein Number-Klassenobjekt über primitiven Daten verwendet werden?  
 

  • Von der Zahlenklasse definierte Konstanten wie MIN_VALUE und MAX_VALUE, die die Ober- und Untergrenzen des Datentyps angeben, sind sehr nützlich.
  • Das Zahlenklassenobjekt kann als Argument einer Methode verwendet werden, die ein Objekt erwartet (wird häufig beim Bearbeiten von Zahlensammlungen verwendet).
  • Klassenmethoden können zum Konvertieren von Werten in und von anderen primitiven Typen, zum Konvertieren in und aus Zeichenfolgen und zum Konvertieren zwischen Zahlensystemen (dezimal, oktal, hexadezimal, binär) verwendet werden.


Methoden, die allen Unterklassen von Number gemeinsam sind:  
 

    xxx xxxValue() : Hier stellt xxx primitive Zahlendatentypen dar (Byte short int long float double). Mit dieser Methode wird der Wert von umgerechnet Das Nummerierungsobjekt für den angegebenen primitiven Datentyp. 
     
  Syntax :    byte byteValue() short shortValue() int intValue() long longValue() float floatValue() double doubleValue()   Parameters :    ----   Returns :   the numeric value represented by this object after conversion to specified type 


 

Java
   //Java program to demonstrate xxxValue() method   public     class   Test   {      public     static     void     main  (  String  []     args  )         {      // Creating a Double Class object with value '6.9685'      Double     d     =     new     Double  (  '6.9685'  );          // Converting this Double(Number) object to       // different primitive data types      byte     b     =     d  .  byteValue  ();         short     s     =     d  .  shortValue  ();         int     i     =     d  .  intValue  ();         long     l     =     d  .  longValue  ();         float     f     =     d  .  floatValue  ();         double     d1     =     d  .  doubleValue  ();             System  .  out  .  println  (  'value of d after converting it to byte : '     +     b  );      System  .  out  .  println  (  'value of d after converting it to short : '     +     s  );      System  .  out  .  println  (  'value of d after converting it to int : '     +     i  );      System  .  out  .  println  (  'value of d after converting it to long : '     +     l  );      System  .  out  .  println  (  'value of d after converting it to float : '     +     f  );      System  .  out  .  println  (  'value of d after converting it to double : '     +     d1  );      }   }   

Ausgabe: 
 

value of d after converting it to byte : 6 value of d after converting it to short : 6 value of d after converting it to int : 6 value of d after converting it to long : 6 value of d after converting it to float : 6.9685 value of d after converting it to double : 6.9685 


Notiz : Beim Konvertieren kann es zu Präzisionsverlusten kommen. Wie wir beispielsweise sehen können, wurde der Bruchteil ('.9685') bei der Konvertierung vom Double-Objekt in den Datentyp int weggelassen. 
 

    int vergleichenTo(NumberSubClass referenceName) : Diese Methode wird zum Vergleichen verwendet Das Nummernobjekt für das angegebene Argument. Da zwei verschiedene Typen jedoch nicht verglichen werden können, sollten sowohl das Argument als auch das Number-Objekt, das die Methode aufruft, vom gleichen Typ sein. Der Referenzname könnte ein Byte Double Integer Float Long oder Short sein. 
     
  Syntax :    public int compareTo( NumberSubClass referenceName )   Parameters :    referenceName - any NumberSubClass type value   Returns :   the value 0 if the Number is equal to the argument. the value 1 if the Number is less than the argument. the value -1 if the Number is greater than the argument. 


 

Java
   //Java program to demonstrate compareTo() method   public     class   Test   {      public     static     void     main  (  String  []     args  )         {      // creating an Integer Class object with value '10'      Integer     i     =     new     Integer  (  '10'  );          // comparing value of i      System  .  out  .  println  (  i  .  compareTo  (  7  ));         System  .  out  .  println  (  i  .  compareTo  (  11  ));         System  .  out  .  println  (  i  .  compareTo  (  10  ));         }   }   


Ausgabe: 
 

1 -1 0 


 

    boolean equals(Object obj) : Diese Methode bestimmt, ob Das Das Zahlenobjekt ist gleich dem Argument. 
     
  Syntax :    public boolean equals(Object obj)   Parameters :    obj - any object   Returns :   The method returns true if the argument is not null and is an object of the same type and with the same numeric value otherwise false. 


 

Java
   //Java program to demonstrate equals() method   public     class   Test   {      public     static     void     main  (  String  []     args  )      {      // creating a Short Class object with value '15'      Short     s     =     new     Short  (  '15'  );          // creating a Short Class object with value '10'      Short     x     =     10  ;          // creating an Integer Class object with value '15'      Integer     y     =     15  ;          // creating another Short Class object with value '15'      Short     z     =     15  ;          //comparing s with other objects      System  .  out  .  println  (  s  .  equals  (  x  ));      System  .  out  .  println  (  s  .  equals  (  y  ));      System  .  out  .  println  (  s  .  equals  (  z  ));      }   }   


Ausgabe: 
 

false false true 


 

    int parseInt(String sint radix) : Diese Methode wird verwendet, um den primitiven Datentyp von a abzurufen Zeichenfolge . Radix wird verwendet, um eine dezimale (10), oktale (8) oder hexadezimale (16) usw. Darstellung als Ausgabe zurückzugeben. 
     
  Syntax :    static int parseInt(String s int radix)   Parameters :    s - any String representation of decimal radix - any radix value   Returns :   the integer value represented by the argument in decimal.   Throws :   NumberFormatException : if the string does not contain a parsable integer. 


 

Java
   //Java program to demonstrate Integer.parseInt() method   public     class   Test   {      public     static     void     main  (  String  []     args  )      {      // parsing different strings      int     z     =     Integer  .  parseInt  (  '654'    8  );         int     a     =     Integer  .  parseInt  (  '-FF'       16  );      long     l     =     Long  .  parseLong  (  '2158611234'    10  );             System  .  out  .  println  (  z  );      System  .  out  .  println  (  a  );      System  .  out  .  println  (  l  );          // run-time NumberFormatException will occur here      // 'Geeks' is not a parsable string      int     x     =     Integer  .  parseInt  (  'Geeks'    8  );             // run-time NumberFormatException will occur here      // (for octal(8)allowed digits are [0-7])      int     y     =     Integer  .  parseInt  (  '99'    8  );             }   }   


Ausgabe: 
 

428 -255 2158611234 Exception in thread 'main' java.lang.NumberFormatException: For input string: 'Geeks' at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Integer.parseInt(Integer.java:580) at Test.main(Test.java:17) 


 

    int parseInt(String s) : Diese Methode ist eine weitere Variante der oben genannten Methode, bei der die Basis standardmäßig 10 (dezimal) ist. 
     
  Syntax :    static int parseInt(String s)   Parameters :    s - any String representation of decimal   Returns :   the integer value represented by the argument in decimal.   Throws :   NumberFormatException : if the string does not contain a parsable integer. 


 

Java
   //Java program to demonstrate Integer.parseInt() method   public     class   Test   {      public     static     void     main  (  String  []     args  )         {      // parsing different strings      int     z     =     Integer  .  parseInt  (  '654'  );         long     l     =     Long  .  parseLong  (  '2158611234'  );             System  .  out  .  println  (  z  );      System  .  out  .  println  (  l  );          // run-time NumberFormatException will occur here      // 'Geeks' is not a parsable string      int     x     =     Integer  .  parseInt  (  'Geeks'  );             // run-time NumberFormatException will occur here      // (for decimal(10)allowed digits are [0-9])      int     a     =     Integer  .  parseInt  (  '-FF'  );          }   }   


Ausgabe: 
 

654 2158611234 Exception in thread 'main' java.lang.NumberFormatException: For input string: 'Geeks' at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Integer.parseInt(Integer.java:580) at java.lang.Integer.parseInt(Integer.java:615) at Test.main(Test.java:15) 


 

    String toString() : Es gibt zwei Varianten der toString()-Methode. Sie werden verwendet, um eine String-Darstellung einer Zahl zu erhalten. Die anderen Varianten dieser Methoden sind Integer.toBinaryString(int i) Integer.toHexString(int i) Integer.toOctalString(int i) Dies gibt eine binäre hexadezimale oktale Zeichenfolgendarstellung der angegebenen Ganzzahl (i) zurück. 
     
  Syntax :    String toString() String toString(int i)   Parameters :    String toString() - no parameter String toString(int i) - i: any integer value   Returns :   String toString() - returns a String object representing the value of the Number object on which it is invoked. String toString(int i) - returns a decimal String object representing the specified integer(i) 
Java
   //Java program to demonstrate Integer.toString()    //and Integer.toString(int i) method   public     class   Test   {      public     static     void     main  (  String  []     args  )      {      // demonstrating toString() method      Integer     x     =     12  ;          System  .  out  .  println  (  x  .  toString  ());             // demonstrating toString(int i) method      System  .  out  .  println  (  Integer  .  toString  (  12  ));          System  .  out  .  println  (  Integer  .  toBinaryString  (  152  ));      System  .  out  .  println  (  Integer  .  toHexString  (  152  ));         System  .  out  .  println  (  Integer  .  toOctalString  (  152  ));      }   }   


Ausgabe: 
 

12 12 10011000 98 230 


 

    Ganzzahliger WertOf() : Es gibt drei Varianten der valueOf()-Methode. Alle diese drei Methoden geben ein Integer-Objekt zurück, das den Wert einer primitiven Ganzzahl enthält. 
     
  Syntax :    Integer valueOf(int i) Integer valueOf(String s) Integer valueOf(String s int radix)   Parameters :    i - any integer value s - any String representation of decimal radix - any radix value   Returns :   valueOf(int i) : an Integer object holding the valuerepresented by the int argument. valueOf(String s) : an Integer object holding value represented by the string argument. valueOf(String s int radix) : an Integer object holding the value represented by the string argument with base radix.   Throws :   valueOf(String s) - NumberFormatException : if the string does not contain a parsable integer. valueOf(String s int radix) - NumberFormatException : if the string does not contain a parsable integer. 


 

Java
   // Java program to demonstrate valueOf() method   public     class   Test   {      public     static     void     main  (  String  []     args  )      {      // demonstrating valueOf(int i) method      System  .  out  .  println  (  'Demonstrating valueOf(int i) method'  );      Integer     i     =  Integer  .  valueOf  (  50  );         Double     d     =     Double  .  valueOf  (  9.36  );         System  .  out  .  println  (  i  );      System  .  out  .  println  (  d  );          // demonstrating valueOf(String s) method      System  .  out  .  println  (  'Demonstrating valueOf(String s) method'  );      Integer     n     =     Integer  .  valueOf  (  '333'  );         Integer     m     =     Integer  .  valueOf  (  '-255'  );         System  .  out  .  println  (  n  );      System  .  out  .  println  (  m  );          // demonstrating valueOf(String sint radix) method      System  .  out  .  println  (  'Demonstrating (String sint radix) method'  );      Integer     y     =     Integer  .  valueOf  (  '333'    8  );         Integer     x     =     Integer  .  valueOf  (  '-255'    16  );         Long     l     =     Long  .  valueOf  (  '51688245'    16  );         System  .  out  .  println  (  y  );      System  .  out  .  println  (  x  );      System  .  out  .  println  (  l  );          // run-time NumberFormatException will occur in below cases      Integer     a     =     Integer  .  valueOf  (  'Geeks'  );      Integer     b     =     Integer  .  valueOf  (  'Geeks'    16  );         }   }   


Ausgabe: 
 

Demonstrating valueOf(int i) method 50 9.36 Demonstrating valueOf(String s) method 333 -255 Demonstrating (String sint radix) method 219 -597 1365803589 Exception in thread 'main' java.lang.NumberFormatException: For input string: 'Geeks' at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Integer.parseInt(Integer.java:580) at java.lang.Integer.valueOf(Integer.java:766) at Test.main(Test.java:28) 


 


Übungsfrage:  
Was ist die Ausgabe des angegebenen Java-Codes?  
 

Java
   public     class   Test   {      public     static     void     main  (  String  []     args  )      {      Integer     i     =     Integer  .  parseInt  (  'Kona'       27  );      System  .  out  .  println  (  i  );      }   }   

Optionen:  
 

A) NumberFormatException at run-time B) NumberFormatException at compile-time C) 411787 


Antwort :  
 

C) 411787 


Erläuterung :  
Da die Basiszahl 27 beträgt, sind in einem String-Literal zulässige Zeichen [0-9][A-Q] (für 10 bis 26). Daher wird sein Wert wie folgt berechnet: 
=> a*(27^0) + n*(27^1) + o*(27^2) + k*(27^3) 
=> 10*1 + 23*27 + 24*27*27 + 20*27*27*27 
=> 10 + 621 + 17496 + 393660 
=> 411787
 

Quiz erstellen