Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Parsing byte array containg fields of unknown length

I am parsing in Java a byte array having the following specification:

Trace data format:
    - 4 bytes containing the Id.
    - 4 bytes containing the address.
    - N bytes containing the first name, where 0 < N < 32
    - N bytes containing the last name, where 0 < N < 32
    - 4 bytes containing the Minimum
    - 4 bytes containing the Maximum 
    - 4 bytes containing the Resource Default Level

Today I don't see any solution to parse this array in order to get 7 variable with the correct type. Do you confirm or Am I missing something like a magic function in Java allowing to find String "limits" in a byte array (I can't see how the Minimum value can be distincted from its associated ASCII character).

Is there any "convention" about a special character between the 2 strings ?

like image 602
Manuel Selva Avatar asked Feb 24 '11 15:02

Manuel Selva


3 Answers

Well, you know that the first name starts at byte 9, and that the last name ends at byte (lenght-13). What is uncertain is how to find where the first name ends and the last name begins. I see a few possible soutions:

  • If the format was defined by a C programmer, the two name fields are most likely terminated by a null byte, since that's the C convention for strings.
  • If it was defined by a Java programmer, it could be written by writeUTF(), which means that the specification of the byte count is most likely wrong. However, this at least specifies the encoding, which is otherwise an open question.
  • If it was defined by a COBOL programmer, the two fields could be fixed-length and padded with zeroes or spaces, with the format specification listing the payload length rather than the field length.
  • If it was defined by a really incompetent programmer (whatever language), it contains the two names without delimiter or count, so it's not possible to realiably separate them (if you don't have the information, there's no "magic" function in Java or elsewhere that can conjure it out of thin air). I suppose you could hope the last name always starts with an uppercase letter and nobody uses double names or all-caps.
like image 74
Michael Borgwardt Avatar answered Sep 27 '22 18:09

Michael Borgwardt


Is there any "convention" about a special character between the 2 strings ?

Well c-strings are often null-terminated \0.

If there is no such character I would say that it is impossible to parse the structure.

like image 44
dacwe Avatar answered Sep 27 '22 18:09

dacwe


Assuming the first and last name are null-terminated you would do it like this:

int firstNameLength = 0;
while(firstNameLength<32) {
    if(theArray[firstNameLength]=='0') break;
    firstNameLength++;
}
int lastNameLength = 0;
while(lastNameLength<32) {
    if(theArray[8+firstNameLength+1+lastNameLength]=='0') break;
    i++;
}
String firstName = new String(theArray).substring(8,8+firstNameLength);
String lastName = new String(theArray).substring(8+firstNameLength+1,8+firstNameLength+1+lastNameLength);
like image 32
Bernd Elkemann Avatar answered Sep 27 '22 16:09

Bernd Elkemann