我正在使用Android Studio开发应用程序,当我从调试转换为发布版本变体时,它开始崩溃.在调试时,它根本不会发生任何事情.真正的问题是我找不到真正的错误,因为每个引用都被重命名.
您是否遇到过这样的错误,仅在发布时发生过?
印刷的堆栈是这样的:
04-11 08:28:42.756 5997-5997/com.korcholis.clothio E/ActivityThread? Failed to inflate android.view.InflateException: Binary XML file line #10: Error inflating class fragment at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.IllegalStateException: Could not find constructor that hast just a (Context) argument for helper class class com.korcholis.clothio.b.c at com.a.a.a.a.a.c(Unknown Source) at com.a.a.a.a.a.b(Unknown Source) at com.a.a.a.a.a.a(Unknown Source) at com.korcholis.clothio.fragments.SampleListFragment.a(Unknown Source) at android.support.v4.app.Fragment.i(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.ae.b(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.w.onCreateView(Unknown Source) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.NoSuchMethodException:[class android.content.Context] at java.lang.Class.getConstructorOrMethod(Class.java:423) at java.lang.Class.getConstructor(Class.java:397) at com.a.a.a.a.a.c(Unknown Source) at com.a.a.a.a.a.b(Unknown Source) at com.a.a.a.a.a.a(Unknown Source) at com.korcholis.clothio.fragments.SampleListFragment.a(Unknown Source) at android.support.v4.app.Fragment.i(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.ae.b(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.w.onCreateView(Unknown Source) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) 04-11 08:28:42.756 5997-5997/com.korcholis.clothio D/AndroidRuntime? Shutting down VM 04-11 08:28:42.756 5997-5997/com.korcholis.clothio W/dalvikvm? threadid=1: thread exiting with uncaught exception (group=0x41902700) 04-11 08:28:42.756 5997-5997/com.korcholis.clothio E/AndroidRuntime? FATAL EXCEPTION: main java.lang.RuntimeException: Unable to start activity ComponentInfo{com.korcholis.clothio/com.korcholis.clothio.SampleListActivity}: android.view.InflateException: Binary XML file line #10: Error inflating class fragment at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2355) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) Caused by: android.view.InflateException: Binary XML file line #10: Error inflating class fragment at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.IllegalStateException: Could not find constructor that hast just a (Context) argument for helper class class com.korcholis.clothio.b.c at com.a.a.a.a.a.c(Unknown Source) at com.a.a.a.a.a.b(Unknown Source) at com.a.a.a.a.a.a(Unknown Source) at com.korcholis.clothio.fragments.SampleListFragment.a(Unknown Source) at android.support.v4.app.Fragment.i(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.ae.b(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.w.onCreateView(Unknown Source) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.NoSuchMethodException: [class android.content.Context] at java.lang.Class.getConstructorOrMethod(Class.java:423) at java.lang.Class.getConstructor(Class.java:397) at com.a.a.a.a.a.c(Unknown Source) at com.a.a.a.a.a.b(Unknown Source) at com.a.a.a.a.a.a(Unknown Source) at com.korcholis.clothio.fragments.SampleListFragment.a(Unknown Source) at android.support.v4.app.Fragment.i(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.ae.b(Unknown Source) at android.support.v4.app.ae.a(Unknown Source) at android.support.v4.app.w.onCreateView(Unknown Source) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) at android.view.LayoutInflater.inflate(LayoutInflater.java:492) at android.view.LayoutInflater.inflate(LayoutInflater.java:397) at android.view.LayoutInflater.inflate(LayoutInflater.java:353) at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:267) at android.app.Activity.setContentView(Activity.java:1906) at android.support.v7.a.g.a(Unknown Source) at android.support.v7.a.n.a(Unknown Source) at android.support.v7.a.g.setContentView(Unknown Source) at com.korcholis.clothio.SampleListActivity.onCreate(Unknown Source) at android.app.Activity.performCreate(Activity.java:5207) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2405) at android.app.ActivityThread.access$600(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5303) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555) at dalvik.system.NativeStart.main(Native Method)
感谢你们
编辑:所以正如AesSedai101所说,这是Proguard和我正在使用的东西之间的问题:Ormlite.所以我将添加标签和一个对我有用的proguard文件:
-keepattributes Signature -keep class com.korcholis.clothio.data.** { *; } -keep class com.j256.** -keepclassmembers class com.j256.** { *; } -keep enum com.j256.** -keepclassmembers enum com.j256.** { *; } -keep interface com.j256.** -keepclassmembers interface com.j256.** { *; }
替换com.korcholis.clothio.data.**
存储数据库模型的包,但不要忘记最终版.**
看起来Proguard正在从你的一个类中删除一个构造函数.请务必按照手册中的说明添加Proguard配置.如果没有添加,Proguard将删除所有未使用的代码,其中包括Activity构造函数.