Android应用程序在长时间空闲时不断崩溃(API 24和23)
我面临着一个有线问题,每当我的应用程序空闲时(点击锁屏按钮后)就会崩溃,但只有在API 24和23上,我已经在棒棒糖和更低的版本上对它进行了测试,它仍然正常恢复 我遇到了一份关于新电池优化系统的文档 但据我所知,这与活动生命周期有关(暂停、恢复…) PS:我只用一个简单的YouTube活动进行测试,没有其他组件,但它仍然崩溃 Java源代码Android应用程序在长时间空闲时不断崩溃(API 24和23),android,crash,android-6.0-marshmallow,android-7.0-nougat,Android,Crash,Android 6.0 Marshmallow,Android 7.0 Nougat,我面临着一个有线问题,每当我的应用程序空闲时(点击锁屏按钮后)就会崩溃,但只有在API 24和23上,我已经在棒棒糖和更低的版本上对它进行了测试,它仍然正常恢复 我遇到了一份关于新电池优化系统的文档 但据我所知,这与活动生命周期有关(暂停、恢复…) PS:我只用一个简单的YouTube活动进行测试,没有其他组件,但它仍然崩溃 Java源代码 public class PlayerActivity extends YouTubeBaseActivity implements YouTubePlay
public class PlayerActivity extends YouTubeBaseActivity implements YouTubePlayer.OnInitializedListener {
private YouTubePlayer youTubePlayer;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_player);
// Initializing YouTube player view
YouTubePlayerView youTubePlayerView = findViewById(R.id.youtube_player_view);
youTubePlayerView.initialize(Constants.YOUTUBE_API_KEY, this);
}
@Override
public void onInitializationSuccess(YouTubePlayer.Provider provider, YouTubePlayer youTubePlayer, boolean wasRestored) {
if(null== youTubePlayer) return;
this.youTubePlayer = youTubePlayer;
// Start buffering
if (!wasRestored) {
youTubePlayer.loadVideo("gsjtg7m1MMM");
}
}
@Override
public void onInitializationFailure(YouTubePlayer.Provider provider, YouTubeInitializationResult youTubeInitializationResult) {
}
@Override
protected void onDestroy() {
super.onDestroy();
youTubePlayer = null;
}
}
布局:
FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/activity_player">
<com.google.android.youtube.player.YouTubePlayerView
android:id="@+id/youtube_player_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
09-13 13:03:29.939 21317-21317/info.digibox.replaytv D/AndroidRuntime:关闭虚拟机
09-13 13:03:29.941 21317-21317/info.digibox.replaytv E/UncaughtException:java.lang.RuntimeException:无法启动活动组件信息{info.digibox.replaytv/info.digibox.replaytv.activities.PlayerActivity}:android.os.BadParcelableException:ClassNotFoundException当解组时:aps
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2984)上
位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045)
位于android.app.ActivityThread.-wrap14(ActivityThread.java)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642)
位于android.os.Handler.dispatchMessage(Handler.java:102)
位于android.os.Looper.loop(Looper.java:154)
位于android.app.ActivityThread.main(ActivityThread.java:6776)
位于java.lang.reflect.Method.invoke(本机方法)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run上(ZygoteInit.java:1496)
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
原因:android.os.BadParcelableException:ClassNotFoundException解组时:aps
位于android.os.Parcel.readParcelableCreator(Parcel.java:2545)
位于android.os.Parcel.readParcelable(Parcel.java:2471)
位于android.os.Parcel.readValue(Parcel.java:2374)
位于android.os.Parcel.readSparseArrayInternal(Parcel.java:2808)
在android.os.Parcel.readSparseArray(Parcel.java:2077)
位于android.os.Parcel.readValue(Parcel.java:2431)
位于android.os.Parcel.ReadyArrayMapInternal(Parcel.java:2727)
位于android.os.BaseBundle.unparcel(BaseBundle.java:269)
在android.os.Bundle.getSparseParcelableArray(Bundle.java:910)
在com.android.internal.policy.PhoneWindow.restoreHierarchyState(PhoneWindow.java:2262)上
位于android.app.Activity.onRestoreInstanceState(Activity.java:1128)
在android.app.Activity.performRestoreInstanceState(Activity.java:1083)中
位于android.app.Instrumentation.callActivityOnRestoreInstanceState(Instrumentation.java:1182)
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2947)上
位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045)
位于android.app.ActivityThread.-wrap14(ActivityThread.java)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642)
位于android.os.Handler.dispatchMessage(Handler.java:102)
位于android.os.Looper.loop(Looper.java:154)
位于android.app.ActivityThread.main(ActivityThread.java:6776)
位于java.lang.reflect.Method.invoke(本机方法)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run上(ZygoteInit.java:1496)
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
09-13 13:03:29.947 21317-21359/info.digibox.replaytv I/FA:找不到标记管理器,因此将不使用
09-13:03:29.950 21317-21359/info.digibox.repla
09-13 13:03:29.936 21317-21317/info.digibox.replaytv E/Parcel: Class not found when unmarshalling: aps
java.lang.ClassNotFoundException: aps
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:400)
at android.os.Parcel.readParcelableCreator(Parcel.java:2517)
at android.os.Parcel.readParcelable(Parcel.java:2471)
at android.os.Parcel.readValue(Parcel.java:2374)
at android.os.Parcel.readSparseArrayInternal(Parcel.java:2808)
at android.os.Parcel.readSparseArray(Parcel.java:2077)
at android.os.Parcel.readValue(Parcel.java:2431)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2727)
at android.os.BaseBundle.unparcel(BaseBundle.java:269)
at android.os.Bundle.getSparseParcelableArray(Bundle.java:910)
at com.android.internal.policy.PhoneWindow.restoreHierarchyState(PhoneWindow.java:2262)
at android.app.Activity.onRestoreInstanceState(Activity.java:1128)
at android.app.Activity.performRestoreInstanceState(Activity.java:1083)
at android.app.Instrumentation.callActivityOnRestoreInstanceState(Instrumentation.java:1182)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2947)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045)
at android.app.ActivityThread.-wrap14(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6776)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1496)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
Caused by: java.lang.ClassNotFoundException: Didn't find class "aps" on path: DexPathList[[zip file "/data/app/info.digibox.replaytv-1/base.apk"],nativeLibraryDirectories=[/data/app/info.digibox.replaytv-1/lib/arm, /data/app/info.digibox.replaytv-1/base.apk!/lib/armeabi-v7a, /system/lib, /vendor/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:400)
at android.os.Parcel.readParcelableCreator(Parcel.java:2517)
at android.os.Parcel.readParcelable(Parcel.java:2471)
at android.os.Parcel.readValue(Parcel.java:2374)
at android.os.Parcel.readSparseArrayInternal(Parcel.java:2808)
at android.os.Parcel.readSparseArray(Parcel.java:2077)
at android.os.Parcel.readValue(Parcel.java:2431)
at android.os.Parcel.readArrayMapInternal(Parcel.java:2727)
at android.os.BaseBundle.unparcel(BaseBundle.java:269)
at android.os.Bundle.getSparseParcelableArray(Bundle.java:910)
at com.android.internal.policy.PhoneWindow.restoreHierarchyState(PhoneWindow.java:2262)
at android.app.Activity.onRestoreInstanceState(Activity.java:1128)
at android.app.Activity.performRestoreInstanceState(Activity.java:1083)
at android.app.Instrumentation.callActivityOnRestoreInstanceState(Instrumentation.java:1182)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2947)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045)
at android.app.ActivityThread.-wrap14(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6776)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1496)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
public class PlayerActivity extends YouTubeBaseActivity implements YouTubePlayer.OnInitializedListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_player);
// Initializing YouTube player view
YouTubePlayerView youTubePlayerView = findViewById(R.id.youtube_player_view);
youTubePlayerView.initialize(Constants.YOUTUBE_API_KEY, this);
}
@Override
public void onInitializationSuccess(YouTubePlayer.Provider provider, YouTubePlayer youTubePlayer, boolean wasRestored) {
if(null== youTubePlayer) return;
// Start buffering
if (!wasRestored) {
youTubePlayer.loadVideo("gsjtg7m1MMM");
}
}
@Override
public void onInitializationFailure(YouTubePlayer.Provider provider, YouTubeInitializationResult youTubeInitializationResult) {
}
}