【问题标题】:Application runs on emulator but not in real device应用程序在模拟器上运行,但不在真实设备上
【发布时间】:2014-09-01 17:50:12
【问题描述】:

我开发了一个android 应用程序。启动应用程序后,它会显示启动画面和登录信息,它可以在 emulatorreal device 上完美运行,但是当我按下跳过选项时设备应用程序崩溃但不在模拟器中。这是错误的logcat:

07-11 12:48:59.735: D/skia(4382): jpeg_decoder mode 1, config 6, w 640, h 1136, sample 

1, bsLength 142a5!!
07-11 12:49:01.589: D/libc-netbsd(4382): getaddrinfo: autolife.com.np get result from proxy >>
07-11 12:49:02.126: D/skia(4382): jpeg_decoder mode 1, config 6, w 640, h 1136, sample 1, bsLength f1ae!!
07-11 12:49:08.694: W/dalvikvm(4382): VFY: unable to resolve virtual method 62: Landroid/app/ActionBar;.setHomeAsUpIndicator (I)V
07-11 12:49:08.868: E/AndroidRuntime(4382): FATAL EXCEPTION: main
07-11 12:49:08.868: E/AndroidRuntime(4382): java.lang.NoSuchMethodError: android.app.ActionBar.setHomeAsUpIndicator
07-11 12:49:08.868: E/AndroidRuntime(4382):     at np.com.autolife.activity.BaseActivity.onCreate(BaseActivity.java:41)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at np.com.autolife.AutoLifeNepal.onCreate(AutoLifeNepal.java:33)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.Activity.performCreate(Activity.java:5122)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1081)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2395)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.ActivityThread.access$600(ActivityThread.java:162)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.os.Handler.dispatchMessage(Handler.java:107)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.os.Looper.loop(Looper.java:194)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at android.app.ActivityThread.main(ActivityThread.java:5371)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at java.lang.reflect.Method.invokeNative(Native Method)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at java.lang.reflect.Method.invoke(Method.java:525)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
07-11 12:49:08.868: E/AndroidRuntime(4382):     at dalvik.system.NativeStart.main(Native Method)

请问有人遇到过这个问题吗?请帮我找出解决方案。提前致谢。

【问题讨论】:

  • 请告诉我下面的答案是否适合您的问题。
  • 您的第二种方法似乎可行,但是当我按照您的程序运行应用程序时,它会出现上述相同的错误。在我的情况下,您的第一种方法无济于事。
  • 对不起,但它必须工作.. 你能发布你的 BaseActivity 代码和你使用的主题吗?我认为你做错了什么。如果(在使用第二种解决方案之后)你有完全相同的堆栈跟踪,这意味着你没有删除导致错误的行(setHomeAsUpIndicator)。
  • 感谢您的回复 :) 在 BaseActivity 上应用您的第一个方法后,它可以正常工作。
  • 但是请告诉你你的 minSdkVersion 是什么——你使用 ActionBarCompat 吗?第一种方法可行,但正如我所提到的,它不会在低于 18 的 API 上更改此图标 - 因此图标保持不变。这意味着没有裂缝,但也没有预期的效果。您应该使用第二个选项从主题设置此图标。

标签: android debugging emulation device


【解决方案1】:

在您的堆栈跟踪日志中,您可以看到 NoSuchMethodError - 这意味着系统无法找到以下方法:android.app.ActionBar.setHomeAsUpIndicator

如文档中所述: http://developer.android.com/reference/android/app/ActionBar.html#setHomeAsUpIndicator(android.graphics.drawable.Drawable)

不知道您要使用哪一个,但都知道:

setHomeAsUpIndicator(Drawable)


setHomeAsUpIndicator(int)

API 级别 18 中添加。 这意味着它们在较低的 API 版本上不可用。这可能是您的问题的原因 - 您正尝试在具有较低 API 版本(低于 JELLY_BEAN_MR2)的手机上执行此代码。

你有两个选择:

。调用此方法前检查 API 版本:

if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.JELLY_BEAN_MR2) {
    actionBar.setHomeAsUpIndicator(int);
}

这将避免崩溃,但不会对较低的 API 版本产生任何影响 - 因此您可能希望使用第二个选项来实现您的样式目标。


。而不是尝试从代码中设置 homeAsUpIndicator - 您可以通过添加“android:homeAsUpIndicator”属性从样式中安全地进行设置(因为它可从 API 11 获得)。 http://developer.android.com/reference/android/R.attr.html#homeAsUpIndicator

<style name="AppTheme" parent="@android:style/Theme.Holo.Light">
    <item name="android:homeAsUpIndicator">@drawable/my_home_as_up_indocator</item>
</style>

您好。

【讨论】:

    猜你喜欢
    • 2016-09-02
    • 1970-01-01
    • 2018-10-23
    • 2014-03-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多