- Java.lang 包類
- Java.lang - 首頁
- Java.lang - Boolean
- Java.lang - Byte
- Java.lang - Character
- Java.lang - Character.Subset
- Java.lang - Character.UnicodeBlock
- Java.lang - Class
- Java.lang - ClassLoader
- Java.lang - Compiler
- Java.lang - Double
- Java.lang - Enum
- Java.lang - Float
- Java.lang - InheritableThreadLocal
- Java.lang - Integer
- Java.lang - Long
- Java.lang - Math
- Java.lang - Number
- Java.lang - Object
- Java.lang - Package
- Java.lang - Process
- Java.lang - ProcessBuilder
- Java.lang - Runtime
- Java.lang - RuntimePermission
- Java.lang - SecurityManager
- Java.lang - Short
- Java.lang - StackTraceElement
- Java.lang - StrictMath
- Java.lang - String
- Java.lang - StringBuffer
- Java.lang - StringBuilder
- Java.lang - System
- Java.lang - Thread
- Java.lang - ThreadGroup
- Java.lang - ThreadLocal
- Java.lang - Throwable
- Java.lang - Void
- Java.lang 包其他
- Java.lang - 介面
- Java.lang - 錯誤
- Java.lang - 異常
- Java.lang 包有用資源
- Java.lang - 有用資源
- Java.lang - 討論
Java - Long highestOneBit() 方法
描述
Java Long highestOneBit() 方法返回一個 long 值,該值最多隻有一個 1 位,位於指定 long 值中最高位(“最左側”)的 1 位的位置。如果指定值在其二進位制補碼錶示形式中沒有 1 位,即如果它等於零,則返回零。
宣告
以下是 java.lang.Long.highestOneBit() 方法的宣告
public static long highestOneBit(long i)
引數
i - 這是 long 值。
返回值
此方法返回一個 long 值,該值只有一個 1 位,位於指定值中最高位的 1 位的位置,如果指定值本身等於零,則返回零。
異常
無
從具有正值的 Long 獲取最高位中最多隻有一個 1 位的 long 值示例
以下示例演示了 Long highestOneBit() 方法的使用,以獲取一個 long 值,該值在最高位的位置最多隻有一個 1 位。我們建立了一個 long 變數併為其分配了一個正 long 值。然後使用 toBinaryString() 方法,我們列印值的二進位制格式。使用 bitCount(),我們列印 1 位的計數,然後使用 highestOneBit() 方法列印最高 1 位的值。
package com.tutorialspoint;
public class LongDemo {
public static void main(String[] args) {
long i = 170L;
System.out.println("Number = " + i);
/* returns the string representation of the unsigned long value
represented by the argument in binary (base 2) */
System.out.println("Binary = " + Long.toBinaryString(i));
// returns the number of one-bits
System.out.println("Number of one bits = " + Long.bitCount(i));
/* returns an long value with at most a single one-bit, in the position
of the highest-order ("leftmost") one-bit in the specified long value */
System.out.println("Highest one bit = " + Long.highestOneBit(i));
}
}
輸出
讓我們編譯並執行上述程式,這將產生以下結果:
Number = 170 Binary = 10101010 Number of one bits = 4 Highest one bit = 128
從具有負值的 Long 獲取最高位中最多隻有一個 1 位的 long 值示例
以下示例演示了 Long highestOneBit() 方法的使用,以獲取一個 long 值,該值在最高位的位置最多隻有一個 1 位。我們建立了一個 long 變數併為其分配了一個負 long 值。然後使用 toBinaryString() 方法,我們列印值的二進位制格式。使用 bitCount(),我們列印 1 位的計數,然後使用 highestOneBit() 方法列印最高 1 位的值。
package com.tutorialspoint;
public class LongDemo {
public static void main(String[] args) {
long i = -170L;
System.out.println("Number = " + i);
/* returns the string representation of the unsigned long value
represented by the argument in binary (base 2) */
System.out.println("Binary = " + Long.toBinaryString(i));
// returns the number of one-bits
System.out.println("Number of one bits = " + Long.bitCount(i));
/* returns an long value with at most a single one-bit, in the position
of the highest-order ("leftmost") one-bit in the specified long value */
System.out.println("Highest one bit = " + Long.highestOneBit(i));
}
}
輸出
讓我們編譯並執行上述程式,這將產生以下結果:
Number = -170 Binary = 1111111111111111111111111111111111111111111111111111111101010110 Number of one bits = 60 Highest one bit = -9223372036854775808
從具有零值的 Long 獲取最高位中最多隻有一個 1 位的 long 值示例
以下示例演示了 Long highestOneBit() 方法的使用,以獲取一個 long 值,該值在最高位的位置最多隻有一個 1 位。我們建立了一個 long 變數併為其分配了一個正 long 值。然後使用 toBinaryString() 方法,我們列印值的二進位制格式。使用 bitCount(),我們列印 1 位的計數,然後使用 highestOneBit() 方法列印最高 1 位的值。
package com.tutorialspoint;
public class LongDemo {
public static void main(String[] args) {
long i = 0L;
System.out.println("Number = " + i);
/* returns the string representation of the unsigned long value
represented by the argument in binary (base 2) */
System.out.println("Binary = " + Long.toBinaryString(i));
// returns the number of one-bits
System.out.println("Number of one bits = " + Long.bitCount(i));
/* returns an long value with at most a single one-bit, in the position
of the highest-order ("leftmost") one-bit in the specified long value */
System.out.println("Highest one bit = " + Long.highestOneBit(i));
}
}
輸出
讓我們編譯並執行上述程式,這將產生以下結果:
Number = 0 Binary = 0 Number of one bits = 0 Highest one bit = 0