switched FragmentPagerAdapter to FragmentStatePagerAdapter-

一:ViewPager适配的时候,刚开始用FragmentPagerAdapter,结果和列表刷新的上滑刷新冲突,导致上滑时候有些时候刷新提示不消失的问题,后来找到了用FragmentStatePagerAdapter适配代替FragmentPagerAdapter完美的解决了这个问题;

二:在华为手机安装百度云OS系统的手机上,隔N久点击app进入,小概率会出现如下异常:

02-05 19:31:43.707: E/Parcel(28308): Class not found when unmarshalling: android.support.v4.view.ViewPager$SavedState, e: java.lang.ClassNotFoundException: android.support.v4.view.ViewPager$SavedState
02-05 19:31:43.740: E/AndroidRuntime(28308): FATAL EXCEPTION: main
02-05 19:31:43.740: E/AndroidRuntime(28308): java.lang.IllegalStateException: Could not execute method of the activity
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$1.onClick(View.java:3607)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View.performClick(View.java:4100)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$PerformClick.run(View.java:17021)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Handler.handleCallback(Handler.java:615)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Handler.dispatchMessage(Handler.java:92)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Looper.loop(Looper.java:137)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.app.ActivityThread.main(ActivityThread.java:4791)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invokeNative(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invoke(Method.java:511)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:766)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:533)
02-05 19:31:43.740: E/AndroidRuntime(28308): at dalvik.system.NativeStart.main(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): Caused by: java.lang.reflect.InvocationTargetException
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invokeNative(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invoke(Method.java:511)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$1.onClick(View.java:3602)
02-05 19:31:43.740: E/AndroidRuntime(28308): ... 11 more
02-05 19:31:43.740: E/AndroidRuntime(28308): Caused by: android.os.BadParcelableException: ClassNotFoundException when unmarshalling: android.support.v4.view.ViewPager$SavedState
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readParcelable(Parcel.java:2077)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readValue(Parcel.java:1965)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readSparseArrayInternal(Parcel.java:2255)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readSparseArray(Parcel.java:1687)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readValue(Parcel.java:2022)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readMapInternal(Parcel.java:2226)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Bundle.unparcel(Bundle.java:223)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Bundle.getSparseParcelableArray(Bundle.java:1232)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:861)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:472)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentStatePagerAdapter.finishUpdate(FragmentStatePagerAdapter.java:163)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.populate(ViewPager.java:1068)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:550)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:509)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItem(ViewPager.java:490)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.jianjian.clock.view.TouchViewPager.setCurrentItem(TouchViewPager.java:49)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.jianjian.clock.activity.MainActivity.onClick(MainActivity.java:243)
02-05 19:31:43.740: E/AndroidRuntime(28308): ... 14 more
02-05 19:31:48.433: E/MediaPlayer(14042): stop called in state 1



为了解决这个问题,在网上找到了如下的解决办法:

引用的网址是:http://stackoverflow.com/questions/11381470/classnotfoundexception-when-unmarshalling-android-support-v4-view-viewpagersav/12466846


    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        final Object fragment = super.instantiateItem(container, position);
        try {
            final Field saveFragmentStateField = Fragment.class.getDeclaredField("mSavedFragmentState");
            saveFragmentStateField.setAccessible(true);
            final Bundle savedFragmentState = (Bundle) saveFragmentStateField.get(fragment);
            if (savedFragmentState != null) {
                savedFragmentState.setClassLoader(Fragment.class.getClassLoader());
            }
        } catch (Exception e) {
            Log.w("CustomFragmentStatePagerAdapter", "Could not get mSavedFragmentState field: " + e);
        }
        return fragment;
    }




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值