Can someone please explain why a member variable (char m_DBFileName[257]
) of static variable (g_JournalDB) getting initialized with a random value? I expect it to be populated with '\0's.
More info: g_JournalDB is part of a dynamic library loaded on app startup via
public class MyApplication extends Application {
static {
System.loadLibrary("mylibrary");
...
System.loadLibrary("mylibraryN");
}
@override
public void onCreate() {...}
...
}
The screenshot above was taken from a breakpoint in onCreate() of MyApplication where g_JournalDB gets created. I can provide more info if needed.
EDIT: Is it possible that, since I am loading multiple .so files, one ore more .so files have overlapping memory map?
EDIT2: In the class constructor of cAMPDatabase, I am doing memset(m_DBFileName, 0, sizeof(m_DBFileName))
so I really expect that it is populated with '\0's.
UPDATE1: Later on in the app, I tried to update the g_JournalDB.m_DBFileName
, I found out that I can no longer access the first 20 indexes. When I did a strncpy(m_DBFileName, "/data", 256);
, the new value started in index 20. As you can see below, my string "/data" starts at index 20.
UPDATE2: I was able to determine that the issue is caused by error in memory:
09-07 07:57:11.417 309-309/? I/DEBUG: *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
09-07 07:57:11.417 309-309/? I/DEBUG: Build fingerprint: 'qcom/msm7808/msm7808:5.1.1/WMY57L/ittech01220402:userdebug/release-keys'
09-07 07:57:11.417 309-309/? I/DEBUG: Revision: '0'
09-07 07:57:11.417 309-309/? I/DEBUG: ABI: 'arm'
09-07 07:57:11.417 309-309/? I/DEBUG: pid: 22437, tid: 22437, name: zapplication.zapp >>> com.zapplication.zapp <<<
09-07 07:57:11.418 309-309/? I/DEBUG: signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x69e793d8
09-07 07:57:11.433 309-309/? I/DEBUG: r0 0056a27c r1 69e371ac r2 0004222c r3 a0bcab7c
09-07 07:57:11.433 309-309/? I/DEBUG: r4 ffffffff r5 a0e29428 r6 be876678 r7 be876618
09-07 07:57:11.433 309-309/? I/DEBUG: r8 be897ab0 r9 b7a7f1c8 sl be897a40 fp b7a7f1c8
09-07 07:57:11.434 309-309/? I/DEBUG: ip a09df2f8 sp be876600 lr a094afa9 pc a094afd8 cpsr 300f0030
09-07 07:57:11.434 309-309/? I/DEBUG: backtrace:
09-07 07:57:11.434 309-309/? I/DEBUG: #00 pc 0001bfd8 /data/app/com.zapplication.zapp-1/lib/arm/libmylibrary.so (_ZN12cAMPDatabase11CreateTableEPKcP18DB_DATA_DEFINITION+79)
UPDATE3: For those who asked, here is the cAMPDatabase class constructor:
cAMPDatabase::cAMPDatabase() {
m_DBHandle = NULL;
memset(m_DBFileName, 0, sizeof(m_DBFileName));
memset(m_Tables, 0, sizeof(m_Tables));
m_TblCount=0;
this->m_SqlObj = this->NewStmt();
}
Here is the header definition (full definition here) for the class:
class cAMPDatabase {
friend class cAMPSqlStmt;
public:
cAMPDatabase();
virtual ~cAMPDatabase();
// the rest of public variables and functions here ...
protected:
char m_DBFileName[257];
// the rest of protected variables and functions here ...
}