9

我有一个应用程序在单独的进程中启动 android 服务。这意味着两个进程正在运行。一个是我的主要应用程序,另一个是服务。

现在我尝试通过以下方法将crittercism(它是一个移动应用程序性能管理工具)集成到其中,但它无法为服务生成崩溃日志。

  1. 仅在应用程序中集成批评。

    结果:它只为应用程序生成崩溃日志,而不是为服务生成崩溃日志。

  2. 在方法中将批评融入服务中onCreate()

    结果:它没有显示崩溃日志,也没有在实时统计中显示应用程序负载。

  3. 在应用程序和服务中集成批评。

    结果:它只为应用程序生成崩溃日志,而不是为服务生成崩溃日志。

那么如何获取android服务的崩溃日志呢?

这是我实现的代码:

MainApplication.java

public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);

    Crittercism.initialize(getApplicationContext(), "CRITTERCISM_APP_ID");
}

我的服务.java

public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);

    Crittercism.initialize(getApplicationContext(), "CRITTERCISM_APP_ID"); // Same app id which is used for MainApplication.java
}

服务和主应用程序的build.gradle文件:

dependencies {
    compile 'com.crittercism:crittercism-android-agent:5.0.6'
}

还为服务和主应用程序添加了以下权限

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
4

1 回答 1

4

我收到了 Crittercism 社区的回复,以下是他们的回复:

The crashes cannot be captured in a remote service and because its Android issue. We also do not count app loads in remote services but other data is collected: HE, Network, etc. Crittercism counts actual app loads only.

One possible work around is to manually wrap all of the top level methods in the service in a try/catch block. In the catch block, use Crittercism.logHandledException.

Here's an example:

try {
customersTopLevelMethod();
} catch (Throwable t) {
Crittercism.logHandledException(t);

// You probably want to rethrow the exception since the service will now
// be in an invalid state.
throw t;
}

这里也是链接 - http://community.crittercism.com/questions/1210/crittercism-not-working-on-android-service-with-se.html#answer-1217

于 2015-07-10T06:01:02.220 回答