1

我这里有一个奇怪的问题。我有一个记录通话的应用程序。为此,我一直在使用广播接收器和在后台运行的服务。但问题是这些东西不提供应用程序图标,因此无法与用户交互。所以我创建了另一个活动并在我的清单中将其声明为启动器活动。现在应用程序有了图标,单击该图标会为用户打开一个 GUI。这是我的清单:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.callrecorderbr.activity"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk android:minSdkVersion="8" />

<application
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >

      <receiver android:name=".EavesDropperReceiver" android:enabled="true">
        <intent-filter>
            <action android:name="android.intent.action.PHONE_STATE"></action>
            <action android:name="android.intent.action.BOOT_COMPLETED"></action>
            <!-- <action android:name="android.intent.action.NEW_OUTGOING_CALL"></action>  -->
        </intent-filter>
    </receiver> 

      <activity android:name=".MainMenuActivity"
              android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen"> 
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <activity
        android:name=".EavesDropperActivity"
        android:label="@string/app_name" >
    </activity> 
    <activity android:name=".RecordingsListActivity"
        android:configChanges="orientation|keyboardHidden"
        android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen" />
    <activity android:name=".PlayRecordingActivity"
        android:configChanges="orientation|keyboardHidden"
        android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen" />


</application>

<!-- <uses-permission android:name="android.permission.INTERNET" /> -->
<!-- <uses-permission android:name="android.permission.WAKE_LOCK" /> -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" /> 
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" /> 
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />


 </manifest>

但是,当应用程序正在运行并且我尝试记录通话时,这种方法给了我一个奇怪的异常。一旦用户开始通话,该应用程序就会冻结并强制退出。它在我的 Logcat 中给出了一些 ANR。这是日志猫:

    07-17 10:21:42.147: E/ActivityManager(59): ANR in com.callrecorderbr.activity (com.callrecorderbr.activity/.EavesDropperActivity)

    07-17 10:21:42.147: E/ActivityManager(59): Reason: keyDispatchingTimedOut

    07-17 10:21:42.147: E/ActivityManager(59): CPU usage from 28362ms to 28ms ago:
    07-17 10:21:42.147: E/ActivityManager(59):   system_server: 8% = 6% user + 1% kernel / faults: 1684 minor 7 major

然后很多关于内核的行与上面的行相同。谁能告诉我是什么问题。请帮我。

4

1 回答 1

1

当任何线程(通常是“主”线程)中存在长时间操作时,就会发生 ANR。要深入研究 /data 文件夹中的 traces.txt 文件。以下链接将帮助您调查 ANR 错误“ANR”

于 2012-07-17T09:20:58.537 回答