Java 我应该把ACRA.init(这个)放在哪里;?

Java 我应该把ACRA.init(这个)放在哪里;?,java,android,logging,acra,Java,Android,Logging,Acra,我开始使用ACRA()进行崩溃报告。测试时,一切都很完美。尽管如此,当我发布应用程序时,我在Google Play控制台中看到了一个错误,这是我发布的版本中的一个新错误,由ACRA.init(this)引起: MyApplication.java:132的内容是: ACRA.init(this); 具有讽刺意味的是,这意味着初始化ACRA导致了崩溃。为了提供一些上下文,我在这里使用了ACRA.init(this): 我在阅读讨论,我读了马尔科姆·库克提出的解决方案: 为了其他人的利益,我发现了

我开始使用ACRA()进行崩溃报告。测试时,一切都很完美。尽管如此,当我发布应用程序时,我在Google Play控制台中看到了一个错误,这是我发布的版本中的一个新错误,由
ACRA.init(this)引起

MyApplication.java:132
的内容是:

ACRA.init(this);
具有讽刺意味的是,这意味着初始化ACRA导致了崩溃。为了提供一些上下文,我在这里使用了
ACRA.init(this)

我在阅读讨论,我读了马尔科姆·库克提出的解决方案:

为了其他人的利益,我发现了我的问题所在

MyDBOpenHelper类是从ContentProvider的onCreate方法触发的,该方法在应用程序类的onCreate方法之前被调用。现在通过在应用程序类中移动acra init方法调用解决了这个问题,如下所示

我应该把
ACRA.init(这个)放在哪里?我在
public void onCreate()
中有它,但它将
java.lang.IllegalStateException
抛出给我。所以我想我应该试着把它放到
受保护的void attachBaseContext(Context base)
,就像马尔科姆·库克建议的那样。谁能确认一下
ACRA.init(这个)的正确位置是什么是什么?多谢各位

更新1:

《实用Android:14高级技术和方法完整项目》(Practical Android:14 Complete Projects on Advanced Technicies and Approach)第3章()提供了一个使用ACRA的项目示例,在其MyApplication.java文件中,他们使用了以下内容:

package com.wickham.android.crashlog;

import org.acra.annotation.ReportsCrashes;
import org.acra.*;
import android.app.Application;

@ReportsCrashes(
                customReportContent = { ReportField.REPORT_ID,
                                        ReportField.APP_VERSION_CODE,
                                        ReportField.APP_VERSION_NAME,
                                        ReportField.PACKAGE_NAME, 
                                        ReportField.PHONE_MODEL, 
                                        ReportField.ANDROID_VERSION, 
                                        ReportField.STACK_TRACE,
                                        ReportField.TOTAL_MEM_SIZE,
                                        ReportField.AVAILABLE_MEM_SIZE,
                                        ReportField.DISPLAY,
                                        ReportField.USER_APP_START_DATE,
                                        ReportField.USER_CRASH_DATE,
                                        ReportField.LOGCAT,
                                        ReportField.DEVICE_ID,
                                        ReportField.SHARED_PREFERENCES,
                                        ReportField.CUSTOM_DATA },
                //formKey = "",
                formUri = "https://example.com/crashed.php",
                httpMethod = org.acra.sender.HttpSender.Method.POST,
                mode = ReportingInteractionMode.TOAST,
                resToastText = R.string.msg_crash_text)

public class MyApplication extends Application
{
    @Override
    public void onCreate() 
    {
        super.onCreate();
        ACRA.init(this);
    }
}
他们正在放置
ACRA.init(this)public void onCreate()中的code>
。它在我测试时对我有效。尽管如此,当我发布该应用程序时,我已经在谷歌Play控制台中看到了一个由
ACRA.init(this)引起的崩溃正如我在问题中解释的。所以我想我可以试着放置
ACRA.init(this)
受保护的void attachBaseContext(Context base)
中。有人能向我澄清一下吗

更新2:

在阅读中,我发现他们有:

import org.acra.*;
import org.acra.annotation.*;

@AcraCore(buildConfigClass = BuildConfig.class)
public class MyApplication extends Application {
    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);

        // The following line triggers the initialization of ACRA
        ACRA.init(this);
    }
}
更新3:


即使我把它放在
attachBaseContext
中,ACRA也会使我的应用程序崩溃:

java.lang.RuntimeException: 
  at android.app.LoadedApk.makeApplication (LoadedApk.java:1164)
  at android.app.ActivityThread.handleBindApplication (ActivityThread.java:6529)
  at android.app.ActivityThread.access$1900 (ActivityThread.java:267)
  at android.app.ActivityThread$H.handleMessage (ActivityThread.java:1963)
  at android.os.Handler.dispatchMessage (Handler.java:109)
  at android.os.Looper.loop (Looper.java:207)
  at android.app.ActivityThread.main (ActivityThread.java:7470)
  at java.lang.reflect.Method.invoke (Native Method)
  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:524)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:958)
Caused by: java.lang.IllegalStateException: 
  at android.app.ContextImpl.startServiceCommon (ContextImpl.java:1842)
  at android.app.ContextImpl.startService (ContextImpl.java:1797)
  at android.content.ContextWrapper.startService (ContextWrapper.java:664)
  at org.acra.sender.SenderServiceStarter.startService (SenderServiceStarter.java:43)
  at org.acra.util.ApplicationStartupProcessor.sendApprovedReports (ApplicationStartupProcessor.java:75)
  at org.acra.ACRA.init (ACRA.java:230)
  at org.acra.ACRA.init (ACRA.java:156)
  at org.acra.ACRA.init (ACRA.java:139)
  at com.myapp.MyApplication.attachBaseContext (MyApplication.java:126)
  at android.app.Application.attach (Application.java:224)
  at android.app.Instrumentation.newApplication (Instrumentation.java:1128)
  at android.app.LoadedApk.makeApplication (LoadedApk.java:1156)

根据上的信息,我的解决方案使用以下方法:

@Override
protected void attachBaseContext(Context base) {
    super.attachBaseContext(base);
    ACRA.init(this, new ConfigurationBuilder(this).build(), false);
    MultiDex.install(this);
}
在日志中,我可以看到
LOGCAT
显示这一行:

08-18 16:31:50.489 I/ACRA    (11890): ACRA is enabled for com.myapp, initializing...

现在初始化成功。

根据上的信息,我的解决方案使用以下方法:

@Override
protected void attachBaseContext(Context base) {
    super.attachBaseContext(base);
    ACRA.init(this, new ConfigurationBuilder(this).build(), false);
    MultiDex.install(this);
}
在日志中,我可以看到
LOGCAT
显示这一行:

08-18 16:31:50.489 I/ACRA    (11890): ACRA is enabled for com.myapp, initializing...

现在初始化成功。

attachBaseContext
是建议进行初始化的位置。生产中不可见的问题通常是由proguard引起的。启用proguard进行测试,以确认。
attachBaseContext
是建议的初始化位置。生产中不可见的问题通常是由proguard引起的。在启用proguard的情况下进行测试,以确认这一点。
08-18 16:31:50.489 I/ACRA    (11890): ACRA is enabled for com.myapp, initializing...