Have:
[46][111][36][11][101][55][87][30][122][75][66][32][49][55][67][77][88][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0][0]
Want:
[46][111][36][11][101][55][87][30][122][75][66][32][49][55][67][77][88]
I have an array of bytes size 8192 to start, and starting at some index in that first array until the end of the array the bytes are all null bytes. So there might be 6000 bytes with values and 2196 null bytes at the end in the array. How do I efficiently create a new array of size (6000) and copy those bytes over? Note: I do not know how many null bytes, or bytes with values there will be.
Here is my try:
static byte[] trim(byte[] bytes) { int i = bytes.length - 1; while (i >= 0 && bytes[i] == 0) { --i; } return Arrays.copyOf(bytes, i + 1); } public static void main(String[] args) { byte[] bytes = { 0, 1, 2, 0, 3, 4, 5, 0, 6, 0, 0, 7, 8, 9, 10, 0, 0, 0, 0 }; byte[] trimmed = trim(bytes); return; }
why not try the static method array copy in the system class just give the source array src start position , destination array , destination start position and the length
System.arraycopy(src, srcPos, dest, destPos, length);
byte [] dest= new byte [6000];
System.arraycopy(src, 0, dest, 0, 6000);
I think we can do in this way also
byte []array={0, 69, 0, 71, 0, 72};
byte ar[]=new String(array).replaceAll("\0", "").getBytes();
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With