发布的应用程序崩溃,但在调试时没有崩溃。

12
我正在使用Android Studio开发一个应用程序,当我从debug切换到release构建变体时,它开始崩溃。在调试过程中根本没有发生任何事情。真正的问题是,我找不到真正的错误所在,因为每个引用都被重命名了。
你是否遇到过像这样的错误,只有在release中才会发生?
打印的堆栈信息如下:
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: <init> [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: <init> [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.**替换为您存储数据库模型的包,但不要忘记最后的. **


请发布您的 SampleListFragment 代码。 - M D
在签署应用程序之前,请删除所有的 Lint 错误。您可以使用以下步骤查找这些错误:右键单击项目 -> Android 工具 -> 运行 Lint。检查常见错误。 - yuva ツ
@SimplePlan 这是一段相当长的内容,这里有个要点概述:https://gist.github.com/Korcholis/10444650 - Sergi Juanola
1
@yuvaツ 好的,我会检查这些错误,但是它怎么可能只在发布模式下出现问题呢? - Sergi Juanola
使用 Lint 错误检查工具,您将找到错误并移除它们。 - yuva ツ
显示剩余4条评论
3个回答

25

看起来Proguard正在从你的一个类中删除构造函数。请确保按照手册中指定的方式添加Proguard配置文件。如果没有添加,Proguard将会删除所有未使用的代码,包括Activity构造函数等内容。


没错!谢谢,我会接受您的答案为有效的。 - Sergi Juanola

2

2

我刚遇到了这个问题,在生成新的签名APK之前运行“Build > Clean Project”可以解决它。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接