-1
我正在增強已經屬於Google來源的本機應用程序。我看到一個崩潰。我試過調試這個,但不能總結。非常感謝您的幫助:Android本機進程:檢測到堆棧損壞
struct device_global {
struct support *sport;
struct support_params params;
struct global_priv *ctrl;
#if defined FEATURE_1
int freq, freq_2;
#endif /* FEATURE_1 */
#ifdef FEATURE_2
int wifi_display;
#define SUBELEMS 10
struct buf *subelem[MAX_SUBELEMS];
#endif /* FEATURE_2 */
struct list_entry *add_list_entry;
#ifdef FEATURE_3
void* my_context;
#endif /* FEATURE_3 */
};
typedef unsigned long DWORD;
typedef DWORD *PDWORD;
typedef struct
{
DWORD dwFlags;
DWORD dwErrorCode;
DWORD dwDeviceId;
#ifdef FEATURE_X
CHAR* tableFileName;
#endif
#ifdef FEATURE_Y
FILE* tableFile;
DWORD headerVersion;
DWORD headerSize;
#endif
} CONTEXT1, *CONTEXT2;
struct device_global * init(struct support_params *params)
{
struct device_global *global;
global = os_malloc(sizeof(*global));
if (params->ctrl)
global->params.ctrl = os_strdup(params->ctrl);
// Assignment of other global variables done here like above (not added here to remove clutter)
int deviceId = 0;
if (0 == getDeviceId(global->my_context, (PDWORD) &deviceId))
{
printf("Device ID 0x%x", deviceId);
}
printf("Before returning global"); // gets printed before crash
return global; // crashes here
}
DWORD getDeviceId(PVOID pContext, PDWORD myDeviceId)
{
CONTEXT2 myContext;
if (!pContext || !myDeviceId)
{
return -1;
}
else
{
myContext = (CONTEXT2) pContext;
*myDeviceId = myContext->dwDeviceId;
}
return 0;
}
崩潰發生在init方法的「return global」處。 printf語句被打印出來,之後出現崩潰。 請分享您的寶貴意見。
對應於崩潰的錯誤信息是:
03-16 12:30:03.230 5626 5626 F DEBUG : signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------
03-16 12:30:03.232 5626 5626 F DEBUG : Abort message: 'stack corruption detected'
你在哪裏爲全局分配內存? – Selvin
已編輯的問題。 malloc在'init'方法中完成。 – webgenius
現在結構內的每個指針指向內存中的一些隨機點。它們的每一次使用都會導致崩潰 – Selvin