草庐IT

c# - Xamarin Android 应用不幸停止工作

coder 2024-07-05 原文

我开始在 Xamarin 中开发一个 Android 应用程序,到目前为止我只在主要布局上做了一些工作(尚未完成),但每次我运行该应用程序以查看布局在模拟器上的外观时,它只是给我“不幸的是 appName(DOS-bot 在这种情况下)已停止工作”。

这是布局 XML:

 <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="#2bced1">
        <ImageView
            android:id="@+id/botModel"
            android:src="@drawable/botModel"
            android:layout_height="match_parent"
            android:layout_width="300dp"
            android:layout_marginBottom="12dp"
            android:layout_marginTop="12dp" />
        <LinearLayout
            android:orientation="vertical"
            android:layout_toRightOf="@id/botModel"
            android:layout_height="fill_parent"
            android:layout_width="fill_parent"
            android:layout_marginTop="12dp"
            android:layout_marginBottom="12dp"
            android:layout_marginRight="8dp">
            <ImageView
                android:id="@+id/Title"
                android:src="@drawable/Title"
                android:layout_width="match_parent"
                android:layout_height="80dp" />
            <ImageButton
                android:id="@+id/NewGame"
                android:layout_width="match_parent"
                android:layout_height="40dp"
                android:layout_marginTop="6dp" />
        </LinearLayout>
    </RelativeLayout>

以及后端代码:

using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
using Android.Content.PM;

namespace DOS_bot
{
    [Activity(Label = "DOS_bot", MainLauncher = true, Icon = "@drawable/icon", Theme = "@android:style/Theme.NoTitleBar.Fullscreen", ScreenOrientation = ScreenOrientation.Landscape)]
    public class MainActivity : Activity
    {         

        protected override void OnCreate(Bundle bundle)
        {
            base.OnCreate(bundle);

            SetContentView(Resource.Layout.Main);

        }
    }
}

在查看 Xamarin 论坛后,我尝试在属性中关闭共享运行时和快速部署以用于发布和调试,但仍然没有用。

这是调试日志,我希望它能对问题有所启发:

07-14 00:31:41.095 I/SurfaceComposerClient(  464): update getting screenshot size 452 x 803
07-14 00:31:41.095 I/SurfaceComposerClient(  464): Opening socket to screenshot pipe.
07-14 00:31:41.095 I/ActivityManager(  464): START u0 {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10200000 cmp=DOS_bot.DOS_bot/md561025751d54c13647beead4a9be33f78.MainActivity} from pid 704
07-14 00:31:41.099 I/DonatelloScreenshot(  464): Capturing screenshot. (w=452 h=803, rot=0, crop l=0 r=1080 t=0 b=1920)
07-14 00:31:41.099 I/DonatelloService(  491): Checking type.
07-14 00:31:41.099 I/DonatelloService(  491): Read hal pipe type Gpu.
07-14 00:31:41.099 I/DonatelloService(  491): Donatello HAL screen shot
07-14 00:31:41.099 I/DonatelloService(  491): Forwarding request
07-14 00:31:41.099 I/DonatelloService(  491): Forwarding data, planning to write 28.
07-14 00:31:41.099 I/DonatelloService(  491): Reallocating bigger buffer
07-14 00:31:41.099 I/DonatelloService(  491): Request sent
07-14 00:31:41.203 I/DonatelloService(  491): Forwarding data, planning to write 1451824.
07-14 00:31:41.203 I/DonatelloService(  491): Reallocating bigger buffer
07-14 00:31:41.359 I/DonatelloService(  491): Done.
07-14 00:31:41.399 I/SurfaceComposerClient(  464): update screenshot succeeded!
07-14 00:31:41.407 D/dalvikvm(  464): GC_FOR_ALLOC freed 744K, 9% free 8611K/9424K, paused 11ms, total 11ms
07-14 00:31:41.407 I/dalvikvm-heap(  464): Grow heap (frag case) to 9.165MB for 723212-byte allocation
07-14 00:31:41.415 D/dalvikvm(  464): GC_FOR_ALLOC freed 14K, 9% free 9302K/10132K, paused 8ms, total 8ms
07-14 00:31:41.419 I/DonatelloService(  491): Channel has closed.
07-14 00:31:41.419 I/DonatelloService(  491): Closing channel.
07-14 00:31:41.435 D/dalvikvm( 1167): Late-enabling CheckJNI
07-14 00:31:41.435 I/ActivityManager(  464): Start proc DOS_bot.DOS_bot for activity DOS_bot.DOS_bot/md561025751d54c13647beead4a9be33f78.MainActivity: pid=1167 uid=10054 gids={50054, 3003}
07-14 00:31:41.455 D/PermissionCache(  139): checking android.permission.READ_FRAME_BUFFER for uid=1000 => granted (164 us)
07-14 00:31:41.455 E/gralloc_donatello(  139): gralloc_alloc: Mismatched usage flags: 1080 x 1920, usage b33
07-14 00:31:41.455 W/GraphicBufferAllocator(  139): alloc(1080, 1920, 1, 00000b33, ...) failed -22 (Invalid argument)
07-14 00:31:41.455 E/        (  139): GraphicBufferAlloc::createGraphicBuffer(w=1080, h=1920) failed (Invalid argument), handle=0x0
07-14 00:31:41.455 E/BufferQueue(  139): [ScreenshotSurface] dequeueBuffer: SurfaceComposer::createGraphicBuffer failed
07-14 00:31:41.479 I/ActivityManager(  464): Config changes=480 {1.0 ?mcc?mnc en_US ldltr sw391dp w654dp h366dp 441dpi nrml land finger qwerty/v/v -nav/h s.6}
07-14 00:31:41.511 D/PhoneStatusBar(  580): mSettingsPanelGravity = 55
07-14 00:31:41.527 I/InputReader(  464): Reconfiguring input devices.  changes=0x00000004
07-14 00:31:41.527 I/InputReader(  464): Device reconfigured: id=3, name='Donatello Virtual Touch Device', size 1080x1920, orientation 1, mode 1, display id 0
07-14 00:31:41.527 I/InputReader(  464): Device reconfigured: id=6, name='Microsoft Vmbus HID-compliant Mouse', size 1080x1920, orientation 1, mode 1, display id 0
07-14 00:31:41.527 I/InputReader(  464): Reconfiguring input devices.  changes=0x00000004
07-14 00:31:41.551 D/AndroidRuntime( 1167): Shutting down VM
07-14 00:31:41.551 W/dalvikvm( 1167): threadid=1: thread exiting with uncaught exception (group=0xa8d2eb20)
07-14 00:31:41.551 E/AndroidRuntime( 1167): FATAL EXCEPTION: main
07-14 00:31:41.551 E/AndroidRuntime( 1167): Process: DOS_bot.DOS_bot, PID: 1167
07-14 00:31:41.551 E/AndroidRuntime( 1167): java.lang.UnsatisfiedLinkError: Couldn't load monodroid from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/DOS_bot.DOS_bot-1.apk"],nativeLibraryDirectories=[/data/app-lib/DOS_bot.DOS_bot-1, /system/lib]]]: findLibrary returned null
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at java.lang.Runtime.loadLibrary(Runtime.java:358)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at java.lang.System.loadLibrary(System.java:526)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at mono.MonoPackageManager.LoadApplication(MonoPackageManager.java:34)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at mono.MonoRuntimeProvider.attachInfo(MonoRuntimeProvider.java:22)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread.installProvider(ActivityThread.java:4774)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread.installContentProviders(ActivityThread.java:4369)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4309)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread.access$1500(ActivityThread.java:135)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.os.Handler.dispatchMessage(Handler.java:102)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.os.Looper.loop(Looper.java:136)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at android.app.ActivityThread.main(ActivityThread.java:5001)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at java.lang.reflect.Method.invokeNative(Native Method)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at java.lang.reflect.Method.invoke(Method.java:515)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
07-14 00:31:41.551 E/AndroidRuntime( 1167):     at dalvik.system.NativeStart.main(Native Method)
07-14 00:31:41.555 W/ActivityManager(  464):   Force finishing activity DOS_bot.DOS_bot/md561025751d54c13647beead4a9be33f78.MainActivity
07-14 00:31:41.603 D/dalvikvm(  580): GC_FOR_ALLOC freed 5328K, 25% free 9594K/12692K, paused 9ms, total 9ms
07-14 00:31:41.607 I/dalvikvm-heap(  580): Grow heap (frag case) to 12.356MB for 3072012-byte allocation
07-14 00:31:41.615 D/dalvikvm(  580): GC_CONCURRENT freed 76K, 21% free 12517K/15696K, paused 1ms+1ms, total 6ms
07-14 00:31:41.659 I/ActivityManager(  464): Config changes=480 {1.0 ?mcc?mnc en_US ldltr sw391dp w391dp h623dp 441dpi nrml port finger qwerty/v/v -nav/h s.7}
07-14 00:31:41.679 I/InputReader(  464): Reconfiguring input devices.  changes=0x00000004
07-14 00:31:41.679 I/InputReader(  464): Device reconfigured: id=3, name='Donatello Virtual Touch Device', size 1080x1920, orientation 0, mode 1, display id 0
07-14 00:31:41.679 I/InputReader(  464): Device reconfigured: id=6, name='Microsoft Vmbus HID-compliant Mouse', size 1080x1920, orientation 0, mode 1, display id 0
07-14 00:31:41.695 E/BluetoothAdapter(  649): Bluetooth binder is null
07-14 00:31:41.743 I/WindowManager(  464): Screen frozen for +293ms due to Window{a9358f48 u0 Application Error: DOS_bot.DOS_bot}
07-14 00:31:41.747 D/dalvikvm(  580): GC_FOR_ALLOC freed 3007K, 25% free 9532K/12692K, paused 3ms, total 4ms
07-14 00:31:41.747 I/dalvikvm-heap(  580): Grow heap (frag case) to 12.295MB for 3072012-byte allocation
07-14 00:31:41.755 D/dalvikvm(  580): GC_CONCURRENT freed 49K, 21% free 12482K/15696K, paused 1ms+1ms, total 7ms
07-14 00:31:41.827 D/PhoneStatusBar(  580): mSettingsPanelGravity = 55
07-14 00:31:42.159 W/ActivityManager(  464): Activity pause timeout for ActivityRecord{a964ea20 u0 DOS_bot.DOS_bot/md561025751d54c13647beead4a9be33f78.MainActivity t3 f}
07-14 00:31:42.187 W/EGL_emulation(  704): eglSurfaceAttrib not implemented
07-14 00:31:43.776 D/dalvikvm(  464): GC_EXPLICIT freed 943K, 14% free 9356K/10840K, paused 0ms+1ms, total 21ms
07-14 00:31:43.840 I/Process ( 1167): Sending signal. PID: 1167 SIG: 9
07-14 00:31:43.840 W/InputMethodManagerService(  464): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@a933e328 attribute=null, token = android.os.BinderProxy@a932cd48
07-14 00:31:43.888 I/ActivityManager(  464): Process DOS_bot.DOS_bot (pid 1167) has died.

最佳答案

来自 Xamarin developer website :

发布应用无法在设备上启动

如果是这样,有两种可能的原因:

  1. .apk 不提供目标设备支持的 ABI。例如,.apk 仅包含 armeabi-v7a 二进制文件,目标设备仅支持 armeabi。
  2. Android 错误。如果是这种情况,请卸载该应用,双手合十,然后重新安装该应用。

要修复 (1),请编辑项目选项/属性并将对所需 ABI 的支持添加到支持的 ABI 列表中。要确定您需要添加哪个 ABI,请针对您的目标设备运行以下 adb 命令:

adb shell getprop ro.product.cpu.abi
adb shell getprop ro.product.cpu.abi2

输出将包含主要(和可选的次要)ABI。

$ adb shell getprop | grep ro.product.cpu
[ro.product.cpu.abi2]: [armeabi]
[ro.product.cpu.abi]: [armeabi-v7a]

关于c# - Xamarin Android 应用不幸停止工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38362094/

有关c# - Xamarin Android 应用不幸停止工作的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  4. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  5. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  6. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  7. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  8. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  9. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  10. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

随机推荐