繁体   English   中英

一段时间后,Android App崩溃了

[英]Android App crashed after some time

我有一个问题,我对导致崩溃的原因一无所知。 我有一个Timer内部类,它每分钟从MainActivity onCreate()触发一次。

timer = new Timer(); 
timer.scheduleAtFixedRate(new RemindTask(),2000, 10000);

这是我的Timer类。此计时器类负责启动另一个活动。

class RemindTask extends TimerTask {

public CaptureActivityHandler cah = new CaptureActivityHandler();
public void run() {
    Log.d("TIMER",  "timer is triggered");
    TimerCount++;

    if(TimerCount > 1)
    {
        Log.d("TIMER",  "TimerCount > 1");
        boolean flag = cah.getDecodeFlag();

        if(flag){
            Log.d("TIMER",  "decodeFlag true");
            cah.setDecodeFlag(false);
            Intent intent = new Intent(MainActivity.this,CaptureActivity.class);
            startActivityForResult(intent,SCAN_QRCODE_REQUEST);
        }
        else
        {
            Intent intent = new Intent(MainActivity.this,CaptureActivity.class);
            startActivityForResult(intent,SCAN_QRCODE_REQUEST);
        }
    }
    else {
        Intent intent = new Intent(MainActivity.this,CaptureActivity.class);
        startActivityForResult(intent,SCAN_QRCODE_REQUEST);
    }
   }
}

问题是该应用在15小时后崩溃了。 Logcat显示:

01-21 11:01:42.027: W/dalvikvm(30401): threadid=11: thread exiting with uncaught  exception (group=0x41ddd930)
01-21 11:01:42.027: W/ActivityManager(363): Unable to find app for caller   android.app.ApplicationThreadProxy@4275bf18 (pid=-1) when starting: Intent {  cmp=com.handalindah.manjalinkkiosk/tw.com.quickmark.sdk.CaptureActivity }
01-21 11:01:42.027: E/AndroidRuntime(30401): FATAL EXCEPTION: Timer-0
01-21 11:01:42.027: E/AndroidRuntime(30401): java.lang.SecurityException: Not allowed to start activity Intent { cmp=com.handalindah.manjalinkkiosk/tw.com.quickmark.sdk.CaptureActivity }
01-21 11:01:42.027: E/AndroidRuntime(30401):    at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1625)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at android.app.Instrumentation.execStartActivity(Instrumentation.java:1417)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at android.app.Activity.startActivityForResult(Activity.java:3370)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at android.app.Activity.startActivityForResult(Activity.java:3331)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:839)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at com.handalindah.manjalinkkiosk.MainActivity$RemindTask.run(MainActivity.java:562)
01-21 11:01:42.027: E/AndroidRuntime(30401):    at java.util.Timer$TimerImpl.run(Timer.java:284)
01-21 11:01:42.037: W/ActivityManager(363): Can't find mystery application for Crash from pid=30401 uid=10079: android.os.BinderProxy@42976028
01-21 11:01:42.037: I/Process(30401): Sending signal. PID: 30401 SIG: 9
01-21 11:01:42.147: W/InputDispatcher(363): channel '42600fd8 com.handalindah.manjalinkkiosk/com.handalindah.manjalinkkiosk.MainActivity (server)' ~ Consumer closed input channel or an error occurred.  events=0x9
01-21 11:01:42.147: E/InputDispatcher(363): channel '42600fd8 com.handalindah.manjalinkkiosk/com.handalindah.manjalinkkiosk.MainActivity (server)' ~ Channel is unrecoverably broken and will be disposed!
01-21 11:01:42.147: W/InputDispatcher(363): Attempted to unregister already unregistered input channel '42600fd8 com.handalindah.manjalinkkiosk/com.handalindah.manjalinkkiosk.MainActivity (server)'
01-21 11:01:42.147: I/WindowState(363): WIN DEATH: Window{42600fd8 u0 com.handalindah.manjalinkkiosk/com.handalindah.manjalinkkiosk.MainActivity}

然后考虑到它可能是由内存泄漏引起的,然后我将计时器周期缩短为10秒。 不出所料,它在2.5小时后崩溃了。

但是,似乎不太可能是因为内存,因为使用的堆大小始终约为58%。 此外,内存使用率约为4%,占设备内存总量100%的3500万。

这是清单。

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

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

<uses-feature android:name="android.hardware.camera" />
<uses-feature android:name="android.hardware.camera.front" />
<uses-feature android:name="android.hardware.camera.autofocus" />

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

<application
    android:largeHeap="true"
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.example.test.MainActivity"
        android:label="@string/app_name"
        android:launchMode="singleTop">
       <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name="tw.com.quickmark.sdk.CaptureActivity"
        android:configChanges="orientation|keyboardHidden"
        android:screenOrientation="portrait"
        android:theme="@android:style/Theme.NoTitleBar.Fullscreen" 
        android:launchMode="singleTop">

    </activity>
    <activity android:name="tw.com.quickmark.sdk.PreferencesActivity" >
    </activity>

    <service
        android:name="com.example.test.MySpiceService"
        android:exported="false" >
    </service>
 </application>
</manifest>

是否想到可能导致崩溃的原因?

不是实际的答案,但您应该将run()方法更改为此。

public void run() {
    Log.d("TIMER",  "timer is triggered");
    TimerCount++;

    if (TimerCount > 1) {
        Log.d("TIMER",  "TimerCount > 1");
        boolean flag = cah.getDecodeFlag();

        if(flag){
            Log.d("TIMER",  "decodeFlag true");
            cah.setDecodeFlag(false);
        }
    }

    Intent intent = new Intent(MainActivity.this,CaptureActivity.class);
            startActivityForResult(intent,SCAN_QRCODE_REQUEST);

}

它做的完全相同,只是重复次数更少。

异常显示为“ java.lang.SecurityException:不允许启动活动意图{cmp = com.handalindah.manjalinkkiosk / tw.com.quickmark.sdk.CaptureActivity}”。

某些运行后,tw.com.quickmark.sdk.CaptureActivity是否未注册?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM