2008-02-19 11:06:52 -07:00
|
|
|
/* Copyright (c) 2008, Avian Contributors
|
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
package java.lang;
|
|
|
|
|
2007-10-28 18:51:08 -06:00
|
|
|
public final class Long extends Number implements Comparable<Long> {
|
2008-03-20 18:40:18 -06:00
|
|
|
public static final Long MIN_VALUE = -9223372036854775808l;
|
|
|
|
public static final Long MAX_VALUE = 9223372036854775807l;
|
|
|
|
|
2007-07-28 10:55:24 -06:00
|
|
|
public static final Class TYPE = Class.forCanonicalName("J");
|
2007-07-26 20:39:53 -06:00
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
private final long value;
|
|
|
|
|
|
|
|
public Long(long value) {
|
|
|
|
this.value = value;
|
|
|
|
}
|
2007-08-12 18:50:25 -06:00
|
|
|
|
2007-09-13 20:19:44 -06:00
|
|
|
public Long(String s) {
|
|
|
|
this.value = parseLong(s);
|
|
|
|
}
|
|
|
|
|
2007-09-26 10:32:02 -06:00
|
|
|
public static Long valueOf(String value) {
|
|
|
|
return new Long(value);
|
|
|
|
}
|
|
|
|
|
2007-08-12 18:50:25 -06:00
|
|
|
public static Long valueOf(long value) {
|
|
|
|
return new Long(value);
|
|
|
|
}
|
2007-07-04 16:27:08 -06:00
|
|
|
|
2007-10-28 18:51:08 -06:00
|
|
|
public int compareTo(Long o) {
|
|
|
|
return value > o.value ? 1 : (value < o.value ? -1 : 0);
|
|
|
|
}
|
|
|
|
|
2007-07-29 17:32:23 -06:00
|
|
|
public boolean equals(Object o) {
|
|
|
|
return o instanceof Long && ((Long) o).value == value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int hashCode() {
|
|
|
|
return (int) ((value >> 32) ^ (value & 0xFF));
|
|
|
|
}
|
|
|
|
|
|
|
|
public String toString() {
|
|
|
|
return String.valueOf(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static String toString(long v, int radix) {
|
|
|
|
if (radix < 1 || radix > 36) {
|
|
|
|
throw new IllegalArgumentException("radix " + radix + " not in [1,36]");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (v == 0) {
|
|
|
|
return "0";
|
|
|
|
}
|
|
|
|
|
2007-08-19 20:57:32 -06:00
|
|
|
boolean negative = v < 0;
|
|
|
|
if (negative) v = -v;
|
|
|
|
|
|
|
|
int size = (negative ? 1 : 0);
|
2007-07-29 17:32:23 -06:00
|
|
|
for (long n = v; n > 0; n /= radix) ++size;
|
|
|
|
|
|
|
|
char[] array = new char[size];
|
|
|
|
|
|
|
|
int i = array.length - 1;
|
|
|
|
for (long n = v; n > 0; n /= radix) {
|
|
|
|
long digit = n % radix;
|
|
|
|
if (digit >= 0 && digit <= 9) {
|
|
|
|
array[i] = (char) ('0' + digit);
|
|
|
|
} else {
|
|
|
|
array[i] = (char) ('a' + (digit - 10));
|
|
|
|
}
|
|
|
|
--i;
|
|
|
|
}
|
|
|
|
|
2007-08-19 20:57:32 -06:00
|
|
|
if (negative) {
|
2007-07-29 17:32:23 -06:00
|
|
|
array[i] = '-';
|
|
|
|
}
|
|
|
|
|
|
|
|
return new String(array);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static String toString(long v) {
|
|
|
|
return toString(v, 10);
|
|
|
|
}
|
|
|
|
|
2007-07-21 11:50:26 -06:00
|
|
|
public byte byteValue() {
|
|
|
|
return (byte) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public short shortValue() {
|
|
|
|
return (short) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int intValue() {
|
|
|
|
return (int) value;
|
|
|
|
}
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
public long longValue() {
|
|
|
|
return value;
|
|
|
|
}
|
2007-07-21 11:50:26 -06:00
|
|
|
|
|
|
|
public float floatValue() {
|
|
|
|
return (float) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double doubleValue() {
|
|
|
|
return (double) value;
|
|
|
|
}
|
2007-07-27 17:56:19 -06:00
|
|
|
|
|
|
|
private static long pow(long a, long b) {
|
|
|
|
long c = 1;
|
|
|
|
for (int i = 0; i < b; ++i) c *= a;
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
2007-08-02 19:49:32 -06:00
|
|
|
public static long parseLong(String s) {
|
|
|
|
return parseLong(s, 10);
|
|
|
|
}
|
|
|
|
|
2007-08-23 20:35:27 -06:00
|
|
|
public static long parseLong(String s, int radix) {
|
|
|
|
int i = 0;
|
2007-07-27 17:56:19 -06:00
|
|
|
long number = 0;
|
2007-08-23 20:35:27 -06:00
|
|
|
boolean negative = s.startsWith("-");
|
|
|
|
if (negative) {
|
|
|
|
i = 1;
|
|
|
|
}
|
2007-07-27 17:56:19 -06:00
|
|
|
|
2007-08-23 20:35:27 -06:00
|
|
|
for (; i < s.length(); ++i) {
|
2007-07-27 17:56:19 -06:00
|
|
|
char c = s.charAt(i);
|
2008-03-20 18:40:18 -06:00
|
|
|
int digit = Character.digit(c, radix);
|
|
|
|
if (digit >= 0) {
|
|
|
|
number += digit * pow(radix, (s.length() - i - 1));
|
|
|
|
} else {
|
|
|
|
throw new NumberFormatException("invalid character " + c + " code " +
|
|
|
|
(int) c);
|
2007-07-27 17:56:19 -06:00
|
|
|
}
|
2007-08-23 20:35:27 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if (negative) {
|
|
|
|
number = -number;
|
2007-07-27 17:56:19 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return number;
|
|
|
|
}
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|