Android - SDK 2.2上的java.lang.VerifyError

时间:2011-07-29 22:40:34

标签: java android gson android-2.2-froyo verifyerror

我最近向市场推出了我的应用程序,并且我已经与一位用户联系,该用户报告当他启动我的应用程序时,它会显示强制关闭/报告对话框。我让用户报告错误,以便我可以看到正在发生的堆栈跟踪,并且我得到了java.lang.VerifyError。

从我读过的内容来看,这与外部库有关,或者在java.lang中的某些方法与目标Android SDK版本不兼容。

用户使用的是Android 2.2.1,但该应用目前适用于许多其他2.2设备,因此我正在尝试找出从哪里开始挖掘。

问题: 有没有人建议什么是最好的事情开始寻找问题?如果需要,我可以提供代码或更多信息,所以请告诉我。

这是堆栈跟踪

java.lang.VerifyError: com.app.myapp.MainActivity
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1429)
at android.app.Instrumentation.newActivity(Instrumentation.java:1034)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2749)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2866)
at android.app.ActivityThread.access$2300(ActivityThread.java:140)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2181)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:5097)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)

提前致谢!

修改
根据Konstantin的要求添加

MainActivity.java

package com.app.myapp;

//Imports removed

public class MainActivity extends BaseActivity implements Runnable {

private LayoutInflater mInflater;
private SharedPreferences prefs;
private SharedPreferences.Editor prefsEditor;

    ....

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    loadActivity(savedInstanceState);
}

private void loadActivity(Bundle savedInstanceState) {
    setContentView(R.layout.mainlayout);

    ActionBar actionBar = (ActionBar)findViewById(R.id.actionbar);
    actionBar.setTitle("My App");
    actionBar.setHomeAction(new IntentAction(this, null, R.drawable.ic_actionbar_home));
    actionBar.addAction(new SearchAction(this, R.drawable.ic_actionbar_search));

    weatherThread = new Thread(this);
    try {
        ....Unrelated Code....

        //****HERE WAS THE PROBLEM****//
        Gson gson = new Gson();

        ....More Unrelated Code....
    } catch (JsonSyntaxException ex) { }

    initMembers();
    initControls();

    if (savedInstanceState != null) {
        mSelectedLayout = savedInstanceState.getInt("CURRENT_TAB");
        setCurrentTab();
    }
    else
        loadMainLayout();
}

    ....Other unrelated code....

}

4 个答案:

答案 0 :(得分:9)

有一些设备在内部使用GSON,但是使库公开,当应用程序尝试引用其打包版本的gson时,会导致命名空间冲突。一种可能的解决方法是使用jarjar更改您包含的gson jar的命名空间。

Heres a thread on the issue - 该主题包含至少一个遇到相同问题的开发人员提供的变通方法的描述。

答案 1 :(得分:2)

可能与您编译的Gson和运行时使用的库等lib不匹配。

参考 - Causes of getting a java.lang.VerifyError

答案 2 :(得分:1)

看起来ActionBar仅在API级别11发布,而android 2.2稍早(API级别8)。所以没有动作栏就试试吧。我不知道这个视图是否被反向移植到2.2平台,但即使它是,你的用户仍然可以拥有旧的2.2版本..

答案 3 :(得分:0)

检查您是否正在针对正确的Android SDK版本进行编译。你的AndroidManifest.xml中的minSDK是什么?