多维数组到字符串(对于android的SQLite)

时间:2011-03-25 14:26:47

标签: java android performance sqlite serialization

Java serialization of multidimensional array

无论如何要将2D数组序列化为内存中的字符串吗?

我正在尝试将2D数组序列化为SQLite3字符串,因此我可以将其放在字段中。上述示例的问题在于作者使用了fileIO,它在移动设备上是速度杀手。

2 个答案:

答案 0 :(得分:2)

此代码将不同大小的int数组序列化为String并将其反序列化为int数组

private static final char NEXT_ITEM = ' ';

public static void main(String[] args) throws IOException {
    int[][] twoD    = new int[][] { new int[] { 1, 2, 2, 4, 4 }, new int[] { 3, 4, 0 }, new int[] { 9 } };

    int[][] newTwoD = null; // will deserialize to this

    System.out.println("Before serialization");

    for(int[] arr : twoD) {
        for(int val : arr) {
            System.out.println(val);
        }
    }

    String str = serialize(twoD);

    System.out.println("Serialized: [" + str + "]");

    newTwoD = deserialize(str);

    System.out.println("After serialization");

    for(int[] arr : newTwoD) {
        for(int val : arr) {
            System.out.println(val);
        }
    }
}

private static String serialize(int[][] array) {
    StringBuilder s = new StringBuilder();
    s.append(array.length).append(NEXT_ITEM);

    for(int[] row : array) {
        s.append(row.length).append(NEXT_ITEM);

        for(int item : row) {
            s.append(String.valueOf(item)).append(NEXT_ITEM);
        }
    }

    return s.toString();
}

private static int[][] deserialize(String str) throws IOException {
    StreamTokenizer tok = new StreamTokenizer(new StringReader(str));
    tok.resetSyntax();
    tok.wordChars('0', '9');
    tok.whitespaceChars(NEXT_ITEM, NEXT_ITEM);
    tok.parseNumbers();

    tok.nextToken();

    int     rows = (int) tok.nval;
    int[][] out  = new int[rows][];

    for(int i = 0; i < rows; i++) {
        tok.nextToken();

        int   length = (int) tok.nval;
        int[] row    = new int[length];
        out[i]       = row;

        for(int j = 0; j < length; j++) {
            tok.nextToken();
            row[j] = (int) tok.nval;
        }
    }

    return out;
}

答案 1 :(得分:1)