Почему при изменении ориентации экрана возникает ClassNotFoundException? - PullRequest
1 голос
/ 09 апреля 2019

Я получаю ClassNotFoundException, когда я поворачиваю свое устройство.Ошибка произошла после того, как я добавил в свой проект библиотеку admob com.google.android.gms: play-services-ads: 17.2.0.Без этой библиотеки все работает нормально.

Я пытался изменить версию библиотеки на 16.0.0, где идентификатор приложения не нужен, ошибка не возникает.

2019-04-09 19:32:16.164 12689-12718/com.example.example.myapplication E/Parcel: Class not found when unmarshalling: android.support.v4.app.FragmentManagerState
    java.lang.ClassNotFoundException: android.support.v4.app.FragmentManagerState
        at java.lang.Class.classForName(Native Method)
        at java.lang.Class.forName(Class.java:400)
        at android.os.Parcel.readParcelableCreator(Parcel.java:2564)
        at android.os.Parcel.readParcelable(Parcel.java:2518)
        at android.os.Parcel.readValue(Parcel.java:2421)
        at android.os.Parcel.readArrayMapInternal(Parcel.java:2788)
        at android.os.BaseBundle.unparcel(BaseBundle.java:271)
        at android.os.Bundle.getBundle(Bundle.java:817)
        at fw.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):33)
        at com.google.android.gms.measurement.internal.AppMeasurementDynamiteService.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):145)
        at cf.a(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):160)
        at k.onTransact(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):4)
        at android.os.Binder.transact(Binder.java:499)
        at com.google.android.gms.internal.measurement.zzq.zza(Unknown Source)
        at com.google.android.gms.internal.measurement.zzdp.onActivityCreated(Unknown Source)
        at com.google.android.gms.internal.measurement.zzex.zzgd(Unknown Source)
        at com.google.android.gms.internal.measurement.zzea$zzb.run(Unknown Source)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
        at java.lang.Thread.run(Thread.java:760)
     Caused by: java.lang.ClassNotFoundException: android.support.v4.app.FragmentManagerState
        at java.lang.Class.classForName(Native Method)
        at java.lang.BootClassLoader.findClass(ClassLoader.java:1346)
        at java.lang.BootClassLoader.loadClass(ClassLoader.java:1406)
        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:2564) 
        at android.os.Parcel.readParcelable(Parcel.java:2518) 
        at android.os.Parcel.readValue(Parcel.java:2421) 
        at android.os.Parcel.readArrayMapInternal(Parcel.java:2788) 
        at android.os.BaseBundle.unparcel(BaseBundle.java:271) 
        at android.os.Bundle.getBundle(Bundle.java:817) 
        at fw.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):33) 
        at com.google.android.gms.measurement.internal.AppMeasurementDynamiteService.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):145) 
        at cf.a(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):160) 
        at k.onTransact(:com.google.android.gms.dynamite_measurementdynamite@16089051@16.0.89 (040408-239467275):4) 
        at android.os.Binder.transact(Binder.java:499) 
        at com.google.android.gms.internal.measurement.zzq.zza(Unknown Source) 
        at com.google.android.gms.internal.measurement.zzdp.onActivityCreated(Unknown Source) 
        at com.google.android.gms.internal.measurement.zzex.zzgd(Unknown Source) 
        at com.google.android.gms.internal.measurement.zzea$zzb.run(Unknown Source) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
        at java.lang.Thread.run(Thread.java:760) 
     Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available

My MainActivity.Ява


public class MainActivity extends AppCompatActivity {
    final Fragment[] fragments = new Fragment[3];
    BottomNavigationView navView;
    FragmentManager fragmentManager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        MobileAds.initialize(this, "ca-app-pub-3940256099942544~3347511713");

        fragmentManager = getSupportFragmentManager();

        Toolbar toolbar = findViewById(R.id.toolbar);
        toolbar.setTitle(getString(R.string.app_name));
        toolbar.setTitleTextColor(Color.WHITE);
        toolbar.setNavigationIcon(R.drawable.ic_navigation);



        navView = findViewById(R.id.nav_view);


        AdView adView = findViewById(R.id.adView);
        adView.loadAd(new AdRequest.Builder().build());


        fragments[0] = new RandomFragment();
        fragments[1] = new FullListFragment();
        fragments[2] = new FavoriteFragment();

        fragmentManager.beginTransaction().add(R.id.main_container2, fragments[0]).commit();


        navView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {

            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {
                Fragment fragment;

                switch (menuItem.getItemId()) {
                    case R.id.navigation_home:
                        fragment = fragments[0];
                        break;

                    case R.id.navigation_dashboard:
                        fragment = fragments[1];
                        break;


                    case R.id.navigation_notifications:
                        fragment = fragments[2];
                        break;

                    default:
                        fragment = fragments[0];
                        break;
                }
                fragmentManager.beginTransaction().replace(R.id.main_container2, fragment).commit();
                return true;
            }
        });
        navView.setSelectedItemId(R.id.navigation_home);
    }


    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);

        outState.putInt("SelectedItemId", navView.getSelectedItemId());

    }


    @Override
    protected void onRestoreInstanceState(Bundle savedInstanceState) {
        super.onRestoreInstanceState(savedInstanceState);
        int selectedItemId = savedInstanceState.getInt("SelectedItemId");
        navView.setSelectedItemId(selectedItemId);
    }


}

Ответы [ 2 ]

0 голосов
/ 23 июня 2019

После долгих размышлений. У меня есть ответ. В новой библиотеке добавлен метод инициализации рекламы с идентификатором приложения, у которого нет внутреннего класса SavedState. Так что все, что нужно, это сохранить appid, как это:

private static final String APP_ID = "your_app_id"

 @Override
    protected void onCreate(Bundle savedInstanceState) {
Bundle adsInstanceState = (savedInstanceState != null)
                ? savedInstanceState.getBundle(APP_ID): null;
        super.onCreate(adsInstanceState);
MobileAds.initialize(this,APP_ID);
}

  @Override
    protected void onSaveInstanceState(@NonNull Bundle outState) {
        super.onSaveInstanceState(outState);
        Bundle adsInstanceState = new Bundle();
        outState.putBundle(APP_ID, adsInstanceState )
   }

Аналогичная проблема, но с картами: https://stackoverflow.com/a/36818004/11334749 Надеюсь, что эта помощь для кого-то

0 голосов
/ 09 апреля 2019

При вращении ваш SupportMapFragment уничтожается и воссоздается.Прежде чем уничтожить, он записывает свое текущее состояние в Посылку, чтобы использовать ее для восстановления своего состояния при воссоздании.Сохраненное состояние фрагмента будет включать в себя состояние его дочерних представлений, и, поскольку вы вложили в него представление AdMob , оно также пытается сохранить и восстановить его. AdMob не имеет необходимого для этого внутреннего класса SavedState, поэтому этот процесс завершается неудачно при попытке восстановить экземпляр AdMob из Parcel.

Решение состоит в том, чтобыне вкладывайте AdMob - или любой другой, если на то пошло, View - в элемент.

Это то, что вы можете сделать, это как и взломать

@Override
public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);

    AdView adView = (AdView)findViewById(R.id.adView);
    View contentFrame = findViewById(R.id.contentFrameLayout);

    RelativeLayout parent = (RelativeLayout) adView.getParent();
    LayoutParams mapFrameParams = contentFrame.getLayoutParams();
    LayoutParams adViewParams = adView.getLayoutParams();

    parent.removeView(adView);
    parent.removeView(contentFrame);

    AdView newAdView = new AdView(this, AdSize.SMART_BANNER, getString(R.string.admob_pubId));

    newAdView.setId(R.id.adView);

    parent.addView(newAdView, adViewParams);
    parent.addView(contentFrame,mapFrameParams);
    newAdView.loadAd(new AdRequest());
}
...