升级到 android 工作室 4,现在报告主要 activity 'is not accessible from class android.app.Instrumentation'
Upgraded to android studio 4, now reports that main activity 'is not accessible from class android.app.Instrumentation'
我每次升级都会出现这种情况,通常是出于不同的原因:
我刚刚升级到 Android Studio 4,我的目标是 android 5/Api21 向上。
这次我的 activity 在启动时崩溃并声称我的主要 activity 'is not accessible from class android.app.Instrumentation'
我不确定 'android.app.Instrumentation' 是什么,或者我的代码中是否有某些要求,依赖项或 android studio 是否需要它。我的主要class是public所以应该可以看到。
我的 class 声明如下所示:
public class AnthracitePlayer extends AppCompatActivity
我认为我用来删除标题栏的 AppCompatActivity 声明如下:
public class AppCompatActivity extends FragmentActivity implements AppCompatCallback,
TaskStackBuilder.SupportParentable, ActionBarDrawerToggle.DelegateProvider {
我的创建方法是这样开始的:
Override
public void onCreate(Bundle savedInstanceState)
{
Log.d(TAG,"Entered onCreate");
super.onCreate(savedInstanceState);
Display display = getWindowManager().getDefaultDisplay();
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
String displayName = display.getName();
我不确定是否有任何这些扰乱了这个仪器的事情。
错误如下:
07-12 14:32:26.251 20528-20528/totga.anthraciteplayerapi21 D/ResourcesManager: creating new AssetManager and set to /data/app/totga.anthraciteplayerapi21-2/base.apk
07-12 14:32:26.341 20528-20528/totga.anthraciteplayerapi21 D/AndroidRuntime: Shutting down VM
07-12 14:32:26.341 20528-20528/totga.anthraciteplayerapi21 E/AndroidRuntime: FATAL EXCEPTION: main
Process: totga.anthraciteplayerapi21, PID: 20528
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{totga.anthraciteplayerapi21/totga.anthraciteplayerapi21.AnthracitePlayer}: java.lang.IllegalAccessException: totga.anthraciteplayerapi21.AnthracitePlayer() is not accessible from class android.app.Instrumentation
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2515)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723)
at android.app.ActivityThread.access0(ActivityThread.java:172)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5832)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
Caused by: java.lang.IllegalAccessException: totga.anthraciteplayerapi21.AnthracitePlayer() is not accessible from class android.app.Instrumentation
at java.lang.Class.newInstance(Class.java:1647)
at android.app.Instrumentation.newActivity(Instrumentation.java:1079)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2505)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723)
at android.app.ActivityThread.access0(ActivityThread.java:172)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5832)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
通过将 onCreate 从 'public' 更改为 'protected',我设法将其设置为 运行(尽管我现在遇到了新问题)。
我认为发生的事情是 android 库中的父 class 的权限发生了变化,或者管理访问级别的规则变得更加严格 - public 应该都有效。
我每次升级都会出现这种情况,通常是出于不同的原因: 我刚刚升级到 Android Studio 4,我的目标是 android 5/Api21 向上。 这次我的 activity 在启动时崩溃并声称我的主要 activity 'is not accessible from class android.app.Instrumentation'
我不确定 'android.app.Instrumentation' 是什么,或者我的代码中是否有某些要求,依赖项或 android studio 是否需要它。我的主要class是public所以应该可以看到。
我的 class 声明如下所示:
public class AnthracitePlayer extends AppCompatActivity
我认为我用来删除标题栏的 AppCompatActivity 声明如下:
public class AppCompatActivity extends FragmentActivity implements AppCompatCallback,
TaskStackBuilder.SupportParentable, ActionBarDrawerToggle.DelegateProvider {
我的创建方法是这样开始的:
Override
public void onCreate(Bundle savedInstanceState)
{
Log.d(TAG,"Entered onCreate");
super.onCreate(savedInstanceState);
Display display = getWindowManager().getDefaultDisplay();
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
String displayName = display.getName();
我不确定是否有任何这些扰乱了这个仪器的事情。 错误如下:
07-12 14:32:26.251 20528-20528/totga.anthraciteplayerapi21 D/ResourcesManager: creating new AssetManager and set to /data/app/totga.anthraciteplayerapi21-2/base.apk 07-12 14:32:26.341 20528-20528/totga.anthraciteplayerapi21 D/AndroidRuntime: Shutting down VM 07-12 14:32:26.341 20528-20528/totga.anthraciteplayerapi21 E/AndroidRuntime: FATAL EXCEPTION: main Process: totga.anthraciteplayerapi21, PID: 20528 java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{totga.anthraciteplayerapi21/totga.anthraciteplayerapi21.AnthracitePlayer}: java.lang.IllegalAccessException: totga.anthraciteplayerapi21.AnthracitePlayer() is not accessible from class android.app.Instrumentation at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2515) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723) at android.app.ActivityThread.access0(ActivityThread.java:172) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:145) at android.app.ActivityThread.main(ActivityThread.java:5832) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) Caused by: java.lang.IllegalAccessException: totga.anthraciteplayerapi21.AnthracitePlayer() is not accessible from class android.app.Instrumentation at java.lang.Class.newInstance(Class.java:1647) at android.app.Instrumentation.newActivity(Instrumentation.java:1079) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2505) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723) at android.app.ActivityThread.access0(ActivityThread.java:172) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:145) at android.app.ActivityThread.main(ActivityThread.java:5832) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
通过将 onCreate 从 'public' 更改为 'protected',我设法将其设置为 运行(尽管我现在遇到了新问题)。 我认为发生的事情是 android 库中的父 class 的权限发生了变化,或者管理访问级别的规则变得更加严格 - public 应该都有效。