public final class Long extends Number implements Comparable<Long>
Long
类包含一个对象中原始类型long
的值。
类型为Long
的对象包含一个单一字段,其类型为long
。
此外,该类还提供了一些将long
转换为String
和String
转换为long
,以及在处理long
时有用的其他常量和方法。
实施说明:“bit twiddling”方法(例如highestOneBit
和numberOfTrailingZeros
)的实现基于Henry S. Warren,Jr.的Hacker's Delight (Addison Wesley,2002)的材料。
Modifier and Type | Field and Description |
---|---|
static int |
BYTES
用于表示二进制补码二进制形式的
long 值的字节数。
|
static long |
MAX_VALUE
一个持有最大值一个
long 可以有2
63 -1。
|
static long |
MIN_VALUE
的常量保持的最小值的
long 可具有-2
63。
|
static int |
SIZE
用于表示二进制补码二进制形式的
long 值的位数。
|
static 类<Long> |
TYPE
类 原始类型
long 的
类 实例。
|
Constructor and Description |
---|
Long(long value)
构造一个新分配的
Long 对象,代表指定的
long 参数。
|
Long(String s)
构造一个新分配
Long 对象,表示
long 由指示值
String 参数。
|
Modifier and Type | Method and Description |
---|---|
static int |
bitCount(long i)
返回指定的long值的二进制补码二进制表示中的
long 数。
|
byte |
byteValue()
返回此值
Long 为
byte 的基本收缩转换后。
|
static int |
compare(long x, long y)
数值比较两个
long 值。
|
int |
compareTo(Long anotherLong)
以数字比较两个
Long 对象。
|
static int |
compareUnsigned(long x, long y)
比较两个
long 值以数值方式将值视为无符号。
|
static Long |
decode(String nm)
将
String 解码为
Long 。
|
static long |
divideUnsigned(long dividend, long divisor)
返回将第一个参数除以秒的无符号商,其中每个参数和结果被解释为无符号值。
|
double |
doubleValue()
返回此值
Long 为
double 一个宽元转换后。
|
boolean |
equals(Object obj)
将此对象与指定的对象进行比较。
|
float |
floatValue()
返回此值
Long 为
float 一个宽元转换后。
|
static Long |
getLong(String nm)
确定
long 具有指定名称的系统属性的值。
|
static Long |
getLong(String nm, long val)
确定
long 具有指定名称的系统属性的值。
|
static Long |
getLong(String nm, Long val)
以指定的
long 返回系统属性的
long 值。
|
int |
hashCode()
返回这个
Long 的哈希码。
|
static int |
hashCode(long value)
返回一个 long 值的哈希码;
兼容Long.hashCode() 。
|
static long |
highestOneBit(long i)
返回一个
long 值至多一个单个1位,在最高阶(“最左侧”)的位置在指定的一个位
long 值。
|
int |
intValue()
在
int 后,返回
Long 作为int的值。
|
long |
longValue()
返回此值
Long 为
long 值。
|
static long |
lowestOneBit(long i)
返回一个
long 值至多一个单个1位,在最低阶(“最右边的”)的位置在指定的一个位
long 值。
|
static long |
max(long a, long b)
返回两个
long 的较大值,就像调用
Math.max 一样 。
|
static long |
min(long a, long b)
返回两个
long 的较小值,就像调用
Math.min 一样 。
|
static int |
numberOfLeadingZeros(long i)
返回的最高阶的(“最左边的”)中所指定的二进制补码表示的一个位前述零个比特的数量
long 值。
|
static int |
numberOfTrailingZeros(long i)
返回零位以下最低阶(“最右边的”)的数量在指定的二进制补码表示的一个位
long 值。
|
static long |
parseLong(String s)
将字符串参数解析为带符号的十进制
long 。
|
static long |
parseLong(String s, int radix)
将字符串参数解析为由第二个参数指定的基数中的带符号的
long 。
|
static long |
parseUnsignedLong(String s)
将字符串参数解析为无符号十进制
long 。
|
static long |
parseUnsignedLong(String s, int radix)
将字符串参数解析为第二个参数指定的基数中的无符号
long 。
|
static long |
remainderUnsigned(long dividend, long divisor)
返回无符号余数,将第一个参数除以秒,其中每个参数和结果被解释为无符号值。
|
static long |
reverse(long i)
返回由指定的二进制补码表示反转位的顺序而获得的值
long 值。
|
static long |
reverseBytes(long i)
返回反转指定的二进制补码表示的字节顺序而获得的值
long 值。
|
static long |
rotateLeft(long i, int distance)
返回通过旋转指定的位数剩下的指定
long 值的二进制补码二进制表示获得的值。
|
static long |
rotateRight(long i, int distance)
返回通过旋转指定的二的补码的二进制表示而得到的值
long 右移位的指定数值。
|
short |
shortValue()
在
short 后,返回
Long 作为short的值。
|
static int |
signum(long i)
返回指定的
long 值的signum函数。
|
static long |
sum(long a, long b)
根据+操作符将两个
long 值一起添加。
|
static String |
toBinaryString(long i)
返回
long 参数的字符串表示形式为基数2中的无符号整数。
|
static String |
toHexString(long i)
返回
long 参数的字符串表示形式,作为16位中的无符号整数。
|
static String |
toOctalString(long i)
返回
long 参数的字符串表示形式,作为基数8中的无符号整数。
|
String |
toString()
返回
String 表示此对象
Long 的价值。
|
static String |
toString(long i)
返回
String 表示指定对象
long 。
|
static String |
toString(long i, int radix)
返回由第二个参数指定的基数中的第一个参数的字符串表示形式。
|
static String |
toUnsignedString(long i)
将参数的字符串表示形式返回为无符号十进制值。
|
static String |
toUnsignedString(long i, int radix)
以第二个参数指定的基数中的无符号整数值返回第一个参数的字符串表示形式。
|
static Long |
valueOf(long l)
返回一个
Long 指定的
long 值的
Long 实例。
|
static Long |
valueOf(String s)
返回一个
Long 指定的
Long 的值的Long
String 。
|
static Long |
valueOf(String s, int radix)
返回一个
Long 对象,该对象保存从指定的String
String 的值,并用第二个参数给出的基数进行解析。
|
@Native public static final long MIN_VALUE
long
可具有-2
63。
@Native public static final long MAX_VALUE
long
可以有2
63 -1。
@Native public static final int SIZE
long
值的位数。
public static final int BYTES
long
值的字节数。
public Long(long value)
Long
对象,该对象表示指定的
long
参数。
value
- 由
Long
对象表示的值。
public Long(String s) throws NumberFormatException
Long
对象,表示long
由指示值String
参数。
该字符串被转换为一个long
在恰好使用的方式值parseLong
为基数10的方法。
s
-
String
要转换为
Long
。
NumberFormatException
- 如果
String
不包含可解析的
long
。
parseLong(java.lang.String, int)
public static String toString(long i, int radix)
如果基数小于Character.MIN_RADIX
或大于Character.MAX_RADIX
,则使用基数10
。
如果第一个参数为负,结果的第一个元素是ASCII减号'-'
( '\u002d'
)。 如果第一个参数不为负,则结果中不会出现符号字符。
结果的剩余字符表示第一个参数的大小。 如果幅度为零,则由单个零字符'0'
( '\u0030'
)表示; 否则,幅度的表示的第一个字符将不是零字符。 以下ASCII字符用作数字:
0123456789abcdefghijklmnopqrstuvwxyz
这些是'\u0030'
至'\u0039'
和'\u0061'
至'\u007a'
。
如果radix
是N ,则这些字符的前N个按照所示的顺序用作小数N位。
因此,十六进制(小数16)的数字是0123456789abcdef
。
如果需要大写字母,则可以对结果调用String.toUpperCase()
方法:
Long.toString(n, 16).toUpperCase()
i
-一个
long
被转换为字符串。
radix
- 在字符串表示中使用的基数。
Character.MAX_RADIX
,
Character.MIN_RADIX
public static String toUnsignedString(long i, int radix)
如果基数小于Character.MIN_RADIX
或大于Character.MAX_RADIX
,则使用基数10
。
请注意,由于第一个参数被视为无符号值,因此不会打印前导符号。
如果幅度为零,则由单个零字符'0'
( '\u0030'
)表示; 否则,幅度的表示的第一个字符将不是零字符。
基数的行为和用作数字的字符与toString
相同。
i
- 要转换为无符号字符串的整数。
radix
- 在字符串表示中使用的基数。
toString(long, int)
public static String toHexString(long i)
long
参数的字符串表示形式,作为16位中的无符号整数。
无符号long
值是参数加上2 64,如果参数为负数; 否则,它等于论证。 该值被转换为十六进制(基数16)的ASCII数字串,没有额外的前导0
s。
可以通过调用Long.parseUnsignedLong(s, 16)
从返回的字符串s
中恢复参数的值。
如果无符号幅度为零,则由单个零字符'0'
( '\u0030'
)表示; 否则,无符号大小的表示的第一个字符将不是零字符。 以下字符用作十六进制数字:
0123456789abcdef
这些是'\u0030'
至'\u0039'
和'\u0061'
至'\u0066'
。
如果需要大写字母,则可以对结果调用String.toUpperCase()
方法:
Long.toHexString(n).toUpperCase()
i
- 一个
long
要转换成一个字符串。
long
值由
long
进制参数(基数16)表示。
parseUnsignedLong(String, int)
,
toUnsignedString(long, int)
public static String toOctalString(long i)
long
参数的字符串表示形式,作为基数8中的无符号整数。
无符号long
值是参数加上2 64,如果参数为负数; 否则,它等于论证。 该值转换为八进制(基数8)中的ASCII数字字符串,没有额外的前导0
s。
可以通过调用Long.parseUnsignedLong(s, 8)
从返回的字符串s
中恢复参数的值。
如果无符号幅度为零,则由单个零字符'0'
( '\u0030'
)表示; 否则,无符号大小的表示的第一个字符将不是零字符。 以下字符用作八进制数字:
01234567
这些人物'\u0030'
通过'\u0037'
。
i
- a
long
要转换为字符串。
long
的字符串表示形式。
parseUnsignedLong(String, int)
,
toUnsignedString(long, int)
public static String toBinaryString(long i)
long
参数的字符串表示形式为基数2中的无符号整数。
无符号long
值是参数加上2 64,如果参数为负数; 否则,它等于论证。 该值转换为二进制(基数2)的ASCII数字字符串,没有额外的前导0
s。
可以通过调用Long.parseUnsignedLong(s, 2)
从返回的字符串s
中恢复参数的值。
如果无符号幅度为零,则由单个零字符'0'
( '\u0030'
)表示; 否则,无符号大小的表示的第一个字符将不是零字符。 字符'0'
( '\u0030'
)和'1'
( '\u0031'
)用作二进制数字。
i
- 一个
long
要转换成一个字符串。
long
值的字符串表示。
parseUnsignedLong(String, int)
,
toUnsignedString(long, int)
public static String toString(long i)
String
对象,表示指定的long
。
参数转换为带符号的十进制表示形式,并作为字符串返回,就像参数和基数10作为toString(long, int)
方法的参数一样。
i
-一个
long
进行转换。
public static String toUnsignedString(long i)
toUnsignedString(long, int)
方法的参数一样。
i
- 要转换为无符号字符串的整数。
toUnsignedString(long, int)
public static long parseLong(String s, int radix) throws NumberFormatException
long
。
字符串中的字符必须是指定基数的数字(如通过是否确定Character.digit(char, int)
返回一个非负的值),所不同的是第一个字符可以是ASCII减号'-'
( '\u002D'
),以指示一个负值或ASCII加号'+'
( '\u002B'
)以表示正值。
返回的结果为long
。
请注意,字符L
( '\u004C'
)和l
( '\u006C'
)均不允许作为类型指示符出现在字符串的末尾,如Java编程语言源代码中允许的L
,除了L
或l
可能显示为数字为大于或等于22的基数。
如果发生以下任何一种情况,则抛出类型NumberFormatException
的异常:
null
或是长度为零的字符串。 radix
或小于Character.MIN_RADIX
或大于Character.MAX_RADIX
。 '-'
( '\u002d'
)或加号'+'
( '\u002B'
),前提是字符串长于长度1。 long
类型的值。 例子:
parseLong("0", 10) returns 0L parseLong("473", 10) returns 473L parseLong("+42", 10) returns 42L parseLong("-0", 10) returns 0L parseLong("-FF", 16) returns -255L parseLong("1100110", 2) returns 102L parseLong("99", 8) throws a NumberFormatException parseLong("Hazelnut", 10) throws a NumberFormatException parseLong("Hazelnut", 36) returns 1356099454469L
s
- 包含要解析的
String
表示的
long
。
radix
- 解析时使用的基数
s
。
long
通过指定基数字符串参数表示。
NumberFormatException
- 如果字符串不包含可解析的
long
。
public static long parseLong(String s) throws NumberFormatException
long
。
字符串中的字符必须都是十进制数字,除了第一个字符可能是ASCII减号'-'
( \u002D'
)以指示负值或ASCII加号'+'
( '\u002B'
)以指示正值。
将所得long
值被返回,就好像该参数和基数10
分别给予作为参数传递给parseLong(java.lang.String, int)
方法。
请注意,字符L
( '\u004C'
)和l
( '\u006C'
)均不允许作为类型指示符出现在字符串的末尾,如Java编程语言源代码中允许的那样。
s
- 一个
String
要解析的
String
表示的
long
long
由十进制参数表示。
NumberFormatException
- 如果字符串不包含可解析的
long
。
public static long parseUnsignedLong(String s, int radix) throws NumberFormatException
long
。
无符号整数将通常与负数相关联的值映射到大于MAX_VALUE
正数。
字符串中的字符必须是指定基数的数字(如通过确定是否Character.digit(char, int)
返回一个非负的值),所不同的是第一个字符可以是ASCII加符号'+'
( '\u002B'
)。
返回所得到的整数值。
如果发生以下任何一种情况,则抛出类型NumberFormatException
的异常:
null
或是长度为零的字符串。 Character.MIN_RADIX
或大于Character.MAX_RADIX
。 '+'
( '\u002B'
),前提是该字符串长于长度1。 long
64 -1。 s
-所述
String
含有无符号整数表示被解析
radix
- 解析时使用的基数
s
。
long
long由指定基数中的字符串参数表示。
NumberFormatException
- 如果
String
不包含可解析的
long
。
public static long parseUnsignedLong(String s) throws NumberFormatException
long
。
字符串中的字符必须都是十进制数字,除了第一个字符可能是ASCII加号'+'
( '\u002B'
)。
返回所得到的整数值,就像参数和基数10作为parseUnsignedLong(java.lang.String, int)
方法的参数一样。
s
- 一个
String
包含待分析的无符号
long
表示
long
值由十进制字符串参数表示
NumberFormatException
- 如果该字符串不包含可分析的无符号整数。
public static Long valueOf(String s, int radix) throws NumberFormatException
Long
对象,该对象保存从指定的String String
的值,并用第二个参数给出的基数进行解析。
第一个参数被解释为在第二个参数指定的基数中表示一个签名的long
,就好像参数被赋予parseLong(java.lang.String, int)
方法一样。
结果是一个Long
对象,表示由字符串指定的long
值。
换句话说,该方法返回一个Long
对象的值等于:
new Long(Long.parseLong(s, radix))
s
- 要解析的字符串
radix
- 用于解释的基数
s
Long
对象。
NumberFormatException
- 如果
String
不包含可解析的
long
。
public static Long valueOf(String s) throws NumberFormatException
Long
指定的Long
的值的Long String
。
该参数被解释为表示一个有符号的十进制long
,正如参数被赋予parseLong(java.lang.String)
方法一样。
结果是一个表示由字符串指定的整数值的Long
对象。
换句话说,此方法返回一个Long
对象的值等于:
new Long(Long.parseLong(s))
s
- 要解析的字符串。
Long
对象。
NumberFormatException
- 如果字符串不能被解析为
long
。
public static Long valueOf(long l)
Long
long
值的Long
实例。
如果不需要新的Long
实例,则该方法通常优先于构造函数Long(long)
使用 ,因为该方法可能通过缓存经常请求的值而产生明显更好的空间和时间性能。
请注意,与corresponding method在Integer
类,这种方法不需要缓存值的特定范围内。
l
- 一个长的价值。
Long
实例,代表
l
。
public static Long decode(String nm) throws NumberFormatException
String
解码成Long
。
接受以下语法给出的十进制,十六进制和八进制数:
DecimalNumeral,HexDigits,和OctalDigits如在The Java™ Language Specification 3.10.1部分所定义,所不同的是下划线不数字之间接受。
- DecodableString:
- Signopt DecimalNumeral
- Signopt
0x
HexDigits- Signopt
0X
HexDigits- Signopt
#
HexDigits- Signopt
0
OctalDigits- Sign:
-
+
可选符号和/或基数说明符(“ 0x
”,“ 0X
”,“ #
”或前导零)之后的Long.parseLong
按Long.parseLong
方法用指定的基数(10,16或8)进行解析。 这个字符序列必须表示一个正值或NumberFormatException
将被抛出。 如果指定的第一个字符的结果是否定String
是减号。 在String中不允许使用String
。
nm
- 要解码的
String
。
Long
对象持有
long
值代表
nm
NumberFormatException
- 如果
String
不包含可解析的
long
。
parseLong(String, int)
public byte byteValue()
Long
为
byte
的基本收缩转换后。
public short shortValue()
Long
为
short
的基本收缩转换后。
shortValue
在
Number
short
之后表示的
short
。
public int intValue()
Long
作为
int
的基本收缩转换之后。
public long longValue()
Long
为
long
值。
public float floatValue()
Long
为
float
一个宽元转换后。
floatValue
在
Number
float
之后表示的
float
。
public double doubleValue()
Long
为
double
一个宽元转换后。
doubleValue
在类别
Number
double
之后表示的
double
。
public String toString()
String
表示此对象Long
的价值。
该值被转换为带符号的十进制表示形式,并作为字符串返回,就像long
值作为toString(long)
方法的参数一样 。
public int hashCode()
Long
的哈希码。
结果是这个Long
对象持有的原始long
值的两半的异或。
也就是说,hashcode是表达式的值:
(int)(this.longValue()^(this.longValue()>>>32))
hashCode
在类别
Object
Object.equals(java.lang.Object)
,
System.identityHashCode(java.lang.Object)
public static int hashCode(long value)
long
值的哈希码;
兼容Long.hashCode()
。
value
- 哈希值
long
值。
public boolean equals(Object obj)
null
并且是Long
对象,其中包含与此对象相同的long
值,则结果为true
。
equals
在类别
Object
obj
- 要比较的对象。
true
如果对象相同;
false
否则。
Object.hashCode()
, HashMap
public static Long getLong(String nm)
long
具有指定名称的系统属性的值。
第一个参数被视为系统属性的名称。 系统属性可通过System.getProperty(java.lang.String)
方法访问。 然后此属性的字符串值被解释为long
使用由支持的语法值decode
和Long
返回表示此值对象。
如果没有指定名称的属性,如果指定的名称为空或null
,或者如果该属性没有正确的数字格式,则返回null
。
换句话说,此方法返回一个Long
对象的值等于:
getLong(nm, null)
nm
- 房产名称。
Long
价值为
Long
。
SecurityException
- 原因与
System.getProperty
相同
System.getProperty(java.lang.String)
,
System.getProperty(java.lang.String, java.lang.String)
public static Long getLong(String nm, long val)
long
具有指定名称的系统属性的值。
第一个参数被视为系统属性的名称。 系统属性可通过System.getProperty(java.lang.String)
方法访问。 然后此属性的字符串值被解释为long
使用由支持的语法值decode
和Long
返回表示此值对象。
第二个参数是默认值。 如果没有指定名称的属性,如果该属性没有正确的数字格式,或者指定的名称为空或为空,则返回表示第二个参数值的Long
对象。
换句话说,此方法返回一个Long
对象的值等于:
getLong(nm, new Long(val))
但实际上可以以下列方式实现:
以避免在不需要默认值时不必要地分配Long result = getLong(nm, null); return (result == null) ? new Long(val) : result;
Long
对象。
nm
- 属性名称。
val
- 默认值。
Long
价值
Long
。
SecurityException
- 原因与
System.getProperty
相同
System.getProperty(java.lang.String)
,
System.getProperty(java.lang.String, java.lang.String)
public static Long getLong(String nm, Long val)
long
值。
第一个参数被视为系统属性的名称。
系统属性可通过System.getProperty(java.lang.String)
方法访问。
然后将该属性的字符串值解释为long
值,按照decode
方法,并返回表示此值的Long
对象;
综上所述:
0x
或ASCII字符# #
,而不是后跟减号,则其余值将被解析为与基数为16的方法valueOf(java.lang.String, int)
完全一样的十六进制整数。 0
后跟另一个字符时,它被解析为一个八进制整数精确地,通过方法valueOf(java.lang.String, int)
用基数8。 valueOf(java.lang.String, int)
。 请注意,在每种情况下, L
( '\u004C'
)和l
( '\u006C'
)都不允许出现在属性值的末尾作为类型指示符,如Java编程语言源代码中允许的那样。
第二个参数是默认值。 如果没有指定名称的属性,如果该属性没有正确的数字格式,或者指定的名称为空或null
,则返回默认值。
nm
- 属性名称。
val
- 默认值。
Long
价值为
Long
。
SecurityException
- 原因与
System.getProperty
相同
System.getProperty(java.lang.String)
,
System.getProperty(java.lang.String, java.lang.String)
public int compareTo(Long anotherLong)
Long
对象。
compareTo
在界面
Comparable<Long>
anotherLong
- 要比较的
Long
。
0
如果这个Long
等于参数Long
;
的值小于0
如果这Long
在数值上小于该参数Long
;
和大于一个值0
如果此Long
在数值上大于该参数Long
(带符号的比较)。
public static int compare(long x, long y)
long
数值。
返回的值与以下内容相同:
Long.valueOf(x).compareTo(Long.valueOf(y))
x
- 第一个
long
进行比较
y
- 第二个
long
进行比较
0
如果x == y
;
一个值小于0
如果x < y
;
和值大于0
如果x > y
public static int compareUnsigned(long x, long y)
long
值进行比较,数值将值视为无符号。
x
- 第一个
long
进行比较
y
- 第二个
long
进行比较
0
如果x == y
;
如果x < y
为无符号值,则小于0
值;
如果x > y
为无符号值,则值大于0
public static long divideUnsigned(long dividend, long divisor)
注意,在二进制补码算术中,如果两个操作数被认为是被签名的或者两个都是无符号的,则加法,减法和乘法的三个其他基本算术运算是逐位相同的。 因此不提供addUnsigned
等方法。
dividend
- 要划分的值
divisor
- 做分割的值
remainderUnsigned(long, long)
public static long remainderUnsigned(long dividend, long divisor)
dividend
- 要分割的值
divisor
- 做分割的值
divideUnsigned(long, long)
public static long highestOneBit(long i)
long
值中,最高位(最左侧)为1位,最多long
返回一个long
值。
如果指定的值在其二进制补码二进制表示中没有1位,也就是说,如果它等于零,则返回零。
i
- 要计算最高一位的值
long
值,具有单个1位,位于指定值中最高位1位的位置,如果指定值本身等于零,则为零。
public static long lowestOneBit(long i)
long
值至多一个单个1位,在最低阶(“最右边的”)的位置在指定的一个位long
值。
如果指定的值在其二进制补码二进制表示中没有1位,也就是说,如果它等于零,则返回零。
i
- 要计算最低一位的值
long
值,具有单个1位,在指定值中的最低位1位的位置,如果指定的值本身等于零,则为零。
public static int numberOfLeadingZeros(long i)
long
值。
如果指定的值在其二进制补码表示中没有一位,换句话说如果它等于零则返回64。
请注意,该方法与对数基数2密切相关。对于所有正值long
值x:
63 - numberOfLeadingZeros(x)
64 - numberOfLeadingZeros(x - 1)
i
- 要计算前导零数的值
long
值,或64如果该值等于零。
public static int numberOfTrailingZeros(long i)
long
值。
如果指定的值在其二进制补码表示中没有一位,换句话说如果它等于零则返回64。
i
- 要计算
i
零的值
long
值,或64如果该值等于零。
public static int bitCount(long i)
long
数。
此功能有时称为人口数量 。
i
- 要对其位进行计数的值
long
数。
public static long rotateLeft(long i, int distance)
long
值。
(左侧移位的位或右侧的高位侧重新输入,或低位)。
请注意,具有负距离的左旋转相当于右旋转: rotateLeft(val, -distance) == rotateRight(val, distance)
。 还要注意,通过64的任意倍数的旋转是无操作的,因此除旋转距离的最后六位之外,除了距离为负值外,也可以忽略旋转距离的最后六位: rotateLeft(val, distance) == rotateLeft(val, distance & 0x3F)
。
i
- 其位要向左旋转的值
distance
- 要向左旋转的位位数
long
值。
public static long rotateRight(long i, int distance)
long
右移位的指定数值。
(右侧移动的位或左侧的低位侧重新输入,或高位)。
请注意,具有负距离的右旋转相当于左旋: rotateRight(val, -distance) == rotateLeft(val, distance)
。 还要注意,通过64的任意倍数的旋转是无操作的,因此除旋转距离的最后六位以外,除了距离为负值外,也可以忽略旋转距离的最后六位: rotateRight(val, distance) == rotateRight(val, distance & 0x3F)
。
i
- 其位要向右旋转的值
distance
- 要向右旋转的位位数
long
值。
public static long reverse(long i)
long
值。
i
- 要反转的值
long
值中反转位的顺序
long
值。
public static int signum(long i)
long
的signum函数。
(如果指定的值为负,返回值为-1;如果指定的值为零,返回值为0;如果指定的值为正,返回值为1)。
i
- 要计算其
i
的值
long
。
public static long reverseBytes(long i)
long
值。
i
- 要颠倒其字节的值
long
值中反转字节获得的值。
public static long sum(long a, long b)
long
值一起添加。
a
- 第一个操作数
b
- 第二个操作数
a
和
b
的总和
BinaryOperator
public static long max(long a, long b)
long
的较大值,就像调用
Math.max
一样 。
a
- 第一个操作数
b
- 第二个操作数
a
和
b
BinaryOperator
public static long min(long a, long b)
long
的较小值,就像调用
Math.min
一样 。
a
- 第一个操作数
b
- 第二个操作数
a
和
b
BinaryOperator
Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2014, Oracle and/or its affiliates. All rights reserved.