mirror of
https://gitee.com/dromara/hutool.git
synced 2025-05-07 22:27:59 +08:00
add method
This commit is contained in:
parent
5550617976
commit
14e53d6e3c
@ -480,7 +480,7 @@ public class ByteUtil {
|
|||||||
return ByteUtil.toBytes(number.shortValue(), byteOrder);
|
return ByteUtil.toBytes(number.shortValue(), byteOrder);
|
||||||
} else if (number instanceof Float) {
|
} else if (number instanceof Float) {
|
||||||
return toBytes(number.floatValue(), byteOrder);
|
return toBytes(number.floatValue(), byteOrder);
|
||||||
} else if(number instanceof BigInteger){
|
} else if (number instanceof BigInteger) {
|
||||||
return ((BigInteger) number).toByteArray();
|
return ((BigInteger) number).toByteArray();
|
||||||
} else {
|
} else {
|
||||||
return toBytes(number.doubleValue(), byteOrder);
|
return toBytes(number.doubleValue(), byteOrder);
|
||||||
@ -620,7 +620,7 @@ public class ByteUtil {
|
|||||||
* @return 连接后的byte[]
|
* @return 连接后的byte[]
|
||||||
* @since 6.0.0
|
* @since 6.0.0
|
||||||
*/
|
*/
|
||||||
public static byte[] concat(final byte[]... byteArrays){
|
public static byte[] concat(final byte[]... byteArrays) {
|
||||||
int totalLength = 0;
|
int totalLength = 0;
|
||||||
for (final byte[] byteArray : byteArrays) {
|
for (final byte[] byteArray : byteArrays) {
|
||||||
totalLength += byteArray.length;
|
totalLength += byteArray.length;
|
||||||
@ -638,10 +638,11 @@ public class ByteUtil {
|
|||||||
*
|
*
|
||||||
* @param buf 无符号bytes
|
* @param buf 无符号bytes
|
||||||
* @return 为 1 的个数
|
* @return 为 1 的个数
|
||||||
|
* @see Integer#bitCount(int)
|
||||||
*/
|
*/
|
||||||
public static int bitCount(final byte[] buf) {
|
public static int bitCount(final byte[] buf) {
|
||||||
int sum = 0;
|
int sum = 0;
|
||||||
for (byte b : buf) {
|
for (final byte b : buf) {
|
||||||
sum += Integer.bitCount((b & 0xFF));
|
sum += Integer.bitCount((b & 0xFF));
|
||||||
}
|
}
|
||||||
return sum;
|
return sum;
|
||||||
@ -654,9 +655,9 @@ public class ByteUtil {
|
|||||||
* @return 位数为1的索引集合
|
* @return 位数为1的索引集合
|
||||||
*/
|
*/
|
||||||
public static List<Integer> toUnsignedBitIndex(final byte[] bytes) {
|
public static List<Integer> toUnsignedBitIndex(final byte[] bytes) {
|
||||||
List<Integer> idxList = new LinkedList<>();
|
final List<Integer> idxList = new LinkedList<>();
|
||||||
StringBuilder sb = new StringBuilder();
|
final StringBuilder sb = new StringBuilder();
|
||||||
for (byte b : bytes) {
|
for (final byte b : bytes) {
|
||||||
sb.append(StrUtil.padPre(Integer.toBinaryString((b & 0xFF)), 8, "0"));
|
sb.append(StrUtil.padPre(Integer.toBinaryString((b & 0xFF)), 8, "0"));
|
||||||
}
|
}
|
||||||
final String bitStr = sb.toString();
|
final String bitStr = sb.toString();
|
||||||
|
@ -196,16 +196,15 @@ public class ByteUtilTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void toUnsignedBitIndex() {
|
public void toUnsignedBitIndex() {
|
||||||
byte[] bytes = {0, 13, -64, -31, 101, 88, 47, -64};
|
final byte[] bytes = {0, 13, -64, -31, 101, 88, 47, -64};
|
||||||
List<Integer> list = ByteUtil.toUnsignedBitIndex(bytes);
|
final List<Integer> list = ByteUtil.toUnsignedBitIndex(bytes);
|
||||||
Console.log(list);
|
Assertions.assertEquals("[12, 13, 15, 16, 17, 24, 25, 26, 31, 33, 34, 37, 39, 41, 43, 44, 50, 52, 53, 54, 55, 56, 57]", list.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void bitCount() {
|
public void bitCount() {
|
||||||
byte[] bytes = {0, 13, -64, -31, 101, 88, 47, -64};
|
final byte[] bytes = {0, 13, -64, -31, 101, 88, 47, -64};
|
||||||
int count = ByteUtil.bitCount(bytes);
|
final int count = ByteUtil.bitCount(bytes);
|
||||||
Console.log(count);
|
|
||||||
Assertions.assertEquals(count, ByteUtil.toUnsignedBitIndex(bytes).size());
|
Assertions.assertEquals(count, ByteUtil.toUnsignedBitIndex(bytes).size());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user