mirror of
https://gitee.com/chinabugotech/hutool.git
synced 2025-04-19 03:01:48 +08:00
add method
This commit is contained in:
parent
5550617976
commit
14e53d6e3c
@ -213,14 +213,14 @@ public class ByteUtil {
|
|||||||
public static int toInt(final byte[] bytes, final int start, final ByteOrder byteOrder) {
|
public static int toInt(final byte[] bytes, final int start, final ByteOrder byteOrder) {
|
||||||
if (ByteOrder.LITTLE_ENDIAN == byteOrder) {
|
if (ByteOrder.LITTLE_ENDIAN == byteOrder) {
|
||||||
return bytes[start] & 0xFF | //
|
return bytes[start] & 0xFF | //
|
||||||
(bytes[1 + start] & 0xFF) << 8 | //
|
(bytes[1 + start] & 0xFF) << 8 | //
|
||||||
(bytes[2 + start] & 0xFF) << 16 | //
|
(bytes[2 + start] & 0xFF) << 16 | //
|
||||||
(bytes[3 + start] & 0xFF) << 24; //
|
(bytes[3 + start] & 0xFF) << 24; //
|
||||||
} else {
|
} else {
|
||||||
return bytes[3 + start] & 0xFF | //
|
return bytes[3 + start] & 0xFF | //
|
||||||
(bytes[2 + start] & 0xFF) << 8 | //
|
(bytes[2 + start] & 0xFF) << 8 | //
|
||||||
(bytes[1 + start] & 0xFF) << 16 | //
|
(bytes[1 + start] & 0xFF) << 16 | //
|
||||||
(bytes[start] & 0xFF) << 24; //
|
(bytes[start] & 0xFF) << 24; //
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -248,18 +248,18 @@ public class ByteUtil {
|
|||||||
|
|
||||||
if (ByteOrder.LITTLE_ENDIAN == byteOrder) {
|
if (ByteOrder.LITTLE_ENDIAN == byteOrder) {
|
||||||
return new byte[]{ //
|
return new byte[]{ //
|
||||||
(byte) (intValue & 0xFF), //
|
(byte) (intValue & 0xFF), //
|
||||||
(byte) ((intValue >> 8) & 0xFF), //
|
(byte) ((intValue >> 8) & 0xFF), //
|
||||||
(byte) ((intValue >> 16) & 0xFF), //
|
(byte) ((intValue >> 16) & 0xFF), //
|
||||||
(byte) ((intValue >> 24) & 0xFF) //
|
(byte) ((intValue >> 24) & 0xFF) //
|
||||||
};
|
};
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
return new byte[]{ //
|
return new byte[]{ //
|
||||||
(byte) ((intValue >> 24) & 0xFF), //
|
(byte) ((intValue >> 24) & 0xFF), //
|
||||||
(byte) ((intValue >> 16) & 0xFF), //
|
(byte) ((intValue >> 16) & 0xFF), //
|
||||||
(byte) ((intValue >> 8) & 0xFF), //
|
(byte) ((intValue >> 8) & 0xFF), //
|
||||||
(byte) (intValue & 0xFF) //
|
(byte) (intValue & 0xFF) //
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -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…
x
Reference in New Issue
Block a user