android - Android Release模式下的 MvxException

标签 android xamarin.android mvvmcross

我遇到了我自己无法解决的问题。我无法在 Release模式下运行我的 android api,它在加载 System.Web.Service.dll 库时停止然后我得到 MvxException,在继续之后我得到了第二个 MvxExcetpion(我猜从 Debug模式它即将关闭应用程序)。

我正在使用 MvvmCross - 我的应用程序在 WindowsPhone7 中运行良好,但在用于 Android 的 Mono 中我遇到了问题。

这是我的输出日志:

- 08-15 17:06:13.242 I/monodroid-gc( 1873): environment supports jni NewWeakGlobalRef
- 08-15 17:06:13.292 W/monodroid-gc( 1873): GREF GC Threshold: 1800
- Loaded assembly: SmartWash.UI.dll
- Loaded assembly: SmartWash.Core.dll
- Loaded assembly: Cirrious.MvvmCross.Android.dll
- Loaded assembly: Newtonsoft.Json.MonoDroid.dll
- Loaded assembly: Cirrious.MvvmCross.Binding.Android.dll
- Loaded assembly: Mono.Android.dll [External]
- Loaded assembly: System.Core.dll [External]
- Loaded assembly: System.dll [External]
- Loaded assembly: MonoDroidConstructors [External]
- Loaded assembly: System.Xml.dll [External]
- Loaded assembly: System.Web.Services.dll [External]
- Unhandled Exception:

- Cirrious.MvvmCross.Exceptions.MvxException: 
- 08-15 17:06:31.972 I/MonoDroid( 1873): UNHANDLED EXCEPTION: Cirrious.MvvmCross.Exceptions.MvxException: No Service Factory Constructor included in Assembly!
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.Platform.MvxServiceProviderSetup.Initialize (System.Type,Cirrious.MvvmCross.Interfaces.IoC.IMvxIoCProvider) <IL 0x0002b, 0x001a8>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.Platform.MvxServiceProviderSetup.Initialize (Cirrious.MvvmCross.Interfaces.IoC.IMvxIoCProvider) <IL 0x00008, 0x0007b>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.IoC.MvxOpenNetCfServiceProviderSetup.Initialize () <IL 0x00007, 0x0008b>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.Platform.MvxBaseSetup.InitializeIoC () <IL 0x00000, 0x00043>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.Platform.MvxBaseSetup.InitializePrimary () <IL 0x00041, 0x001d7>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Cirrious.MvvmCross.Android.Views.MvxBaseSplashScreenActivity.OnCreate (Android.OS.Bundle) <IL 0x00036, 0x0018b>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at SmartWash.UI.SplashScreenActivity.OnCreate (Android.OS.Bundle) <IL 0x00002, 0x0004f>
- 08-15 17:06:31.972 I/MonoDroid( 1873): at Android.App.Activity.n_OnCreate_Landroid_os_Bundle_ (intptr,intptr,intptr) [0x00010] in /Users/builder/data/lanes/monodroid-mac-monodroid-4.2.3-branch/410a5aba/source/monodroid/src/Mono.Android/platforms/android-8/src/generated/Android.App.Activity.cs:1490
- 08-15 17:06:31.972 I/MonoDroid( 1873): at (wrapper dynamic-method) object.891313b6-5c12-4624-844c-14d43e535064 (intptr,intptr,intptr) <IL 0x00012, 0x00033>
- Unhandled Exception:

- Cirrious.MvvmCross.Exceptions.MvxException: 

几天来我一直在寻找解决方案,现在我太累了,无法自己解决。非常欢迎任何建议!

更新: 在链接“仅 SDK”中添加 LinkerIncludePlease.cs 类后,我遇到了另一个 NullReference 问题,我找不到它。

这是我的输出:

- 08-16 10:08:27.922 I/mono    ( 2334):   at Cirrious.MvvmCross.Android.ExtensionMethods.MvxAndroidActivityExtensionMethods.OnViewCreate<TViewModel> (Cirrious.MvvmCross.Android.Interfaces.IMvxAndroidView`1<TViewModel>) <IL 0x00043, 0x00243>
- 08-16 10:08:27.922 I/mono    ( 2334):   at Cirrious.MvvmCross.Android.Views.MvxTabActivityView`1.OnCreate (Android.OS.Bundle) <IL 0x00008, 0x00093>
- 08-16 10:08:27.922 I/mono    ( 2334):   at Cirrious.MvvmCross.Binding.Android.Views.MvxBindingTabActivityView`1.OnCreate (Android.OS.Bundle) <IL 0x00008, 0x00077>
In mgmain JNI_OnLoad
- 08-16 10:08:27.922 I/mono    ( 2334):   at Sm08-16 10:08:27.922 I/mono    ( 2334):   at SmartWash.UI.Views.BaseTabbedView`1.OnCreate (Android.OS.Bundle) <IL 0x0000a, 0x00083>
- 08-16 10:08:27.932 I/mono    ( 2334):   at Android.App.Activity.n_OnCreate_Landroid_os_Bundle_ (intptr,intptr,intptr) <IL 0x00012, 0x000ef>
- 08-16 10:08:27.942 I/mono    ( 2334):   at (wrapper dynamic-method) object.dc29b95c-fdca-49d9-bdbc-e51d024c54c9 (intptr,intptr,intptr) <IL 0x00012, 0x00033>
08-16 10:08:27.942 I/mono    ( 2334):   at (wrapper native-to-managed) object.dc29b95c-fdca-49d9-bdbc-e51d024c54c9 (intptr,intptr,intptr) <IL 0x0001f, 0xffffffff>
- Unhandled Exception:

- System.NullReferenceException: 

- 08-16 10:08:59.102 I/MonoDroid( 2334): UNHANDLED EXCEPTION: System.NullReferenceException: Object reference not set to an instance of an object
- 08-16 10:08:59.102 I/MonoDroid( 2334): at (wrapper delegate-invoke) <Module>.invoke_intptr__this___intptr_intptr_intptr_JValue[] (intptr,intptr,intptr,Android.Runtime.JValue[]) <IL 0x0005d, 0x0011f>
- 08-16 10:08:59.102 I/MonoDroid( 2334): at Android.Runtime.JNIEnv.CallObjectMethod (intptr,intptr,Android.Runtime.JValue[]) <IL 0x00012, 0x000a7>

最佳答案

事实上,这只是 Release模式,加上这是一个缺失的类,这在我看来这可能是一个单体链接问题——单体链接器剥离了太多的类。

解决此问题的最简单方法是将 monodroid 链接设置更改为“仅 SDK”。

更高级的解决方法是在您的主项目中包含对反射加载类的引用。一些 mvx 示例包括此机制的示例 - 查找名为 LinkerPleaseInclude.cs(或类似文件)的文件

关于android - Android Release模式下的 MvxException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11973993/

相关文章:

android - 如何开发像谷歌日历这样的带有粘性列的 ListView

c# - Xamarin forms Picker on android更改取消文本

android - android View 可见性绑定(bind)中的空引用异常

java - Volley请求在android Java中只执行一次

android - 如何更改警报对话框的位置

c# - Xamarin.Android 上的多个彩色 Activity 标签元素

android - 如何在应用程序被杀死时调试应用程序

c# - mvvmcross 从选项卡式导航到 View 模型

xamarin.ios - 在 MvvmCross monodroid Activity 中插入 Monogame View

android 在 ListView 中更改行项目 View 相关的一个 fragment