2

我的应用程序将 VCard 检索为字符串,并通过 StringBuilder 将所有内容组合成一个大字符串

public String getVcardStrings() throws Exception {
    Cursor cursor = context.getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null);
    StringBuilder builder = new StringBuilder();
    if (cursor.moveToFirst()) ;
    do {
        String s = getVCardStringFromContact(cursor);
        L.d("VCARD", s);
        builder.append(s);
    } while (cursor.moveToNext());
    cursor.close();

    L.d("VCARD", "Output: \n" + builder.toString());
    return builder.toString();
}

每个 getVCardAsString() 调用的输出都是正确的。它包含所有数据。但是调用 builder.toString() 只返回 1,5 个联系人的 vcard 数据,大约是 4kb 的文本数据,其余的根本就丢失了!

也不例外,我读过 StringBuilders 的容量理论上可以达到 4GB。现在我的问题是,这里发生了什么?

4

1 回答 1

3

我很确定这是一个误报:

换句话说,数据在那里,但被 logcat 截断。这个观察似乎可以通过这个定义得到验证:

#define LOGGER_ENTRY_MAX_LEN        (4*1024)

这是一个 4KB 的 bang-on 并且与您正在经历的事情直接相关。

将您的输出写入文件以检查其是否确实存在。

于 2013-10-08T18:00:56.430 回答