この奇妙な問題を解決しようとしてほぼ2週間後、私はあきらめました! 基本的に、Android 2.xx から 3.xx を搭載したデバイスでのみアプリを実行しようとするたびに、java.lang.VerifyError が発生します。
プロジェクトでは、次の 2 つの外部ライブラリを使用しています。
- アクション バー シャーロック - http://actionbarsherlock.com/ - v4.4.0 で更新
- スライド メニュー - https://github.com/jfeinstein10/SlidingMenu
これは、LogCat が毎回返すものです。
FATAL EXCEPTION: main
java.lang.VerifyError: me.xxx.menu.MenuListFragment
at me.xxx.menu.BaseSlidingMenuActivity.onCreate(BaseSlidingMenuActivity.java:46)
at me.xxx.menu.SlidingMenuCustomAnimation.onCreate(SlidingMenuCustomAnimation.java:28)
at me.xxx.XXXActivity.onCreate(XXXActivity.java:130)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
at android.app.ActivityThread.access$1500(ActivityThread.java:117)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3683)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
at dalvik.system.NativeStart.main(Native Method)
BaseSlidingMenuActivity.java の 46 行目付近は次のようになります。
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setTitle(mTitleRes);
// set the Behind View
setBehindContentView(R.layout.frame_content);
if (savedInstanceState == null) {
FragmentTransaction t = this.getSupportFragmentManager().beginTransaction();
mFrag = new MenuListFragment(); <--- ERROR HERE!
t.replace(R.id.frame_content, mFrag);
t.commit();
} else {
mFrag =(SherlockListFragment)this.getSupportFragmentManager()
.findFragmentById(R.id.frame_content);
}
...
...
}
MenuListFragment() は、SherlockFragmentActivity を拡張し、SlidingActivityBase を実装する SlidingFragmentActivity です。
もちろん、私は問題をググってみましたが、多くの人が Android SDK ツールの最後のバージョン、つまり v22.xx でこの問題を抱えているようです。実際には v22.6.3 を持っています。
VerifyErrorについての他の会話で説明されているように、「ビルドパス->ビルドパスの構成->注文とエクスポート」メニュー内の「プライベートライブラリ」ボックスにチェックを入れるだけでVerifyErrorを解決した人もいますが、私にとってはうまくいきません。 「プライベートライブラリ」がすでにチェックされているためです。したがって、ライブラリ/インポートの状況は問題ないようです!
誰かがすでにその解決策に資金を提供していることを願っています! 私は夢中になっています!:D
ありがとうございました!