- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发 Xamarin.Android 应用程序,并且正在使用远程 MySql 数据库 (AWS)。连接工作得很好,没有任何问题。但是当用户没有连接(使用飞行模式测试)时,它会崩溃,我无法捕捉到它。
我正在使用自定义类来管理数据库连接。使用 MySqlConnector,我已经 try catch MySqlException。
private MySqlConnection CreateOpenConnection()
{
try
{
if (string.IsNullOrWhiteSpace(connectionString)) throw new Exception("Connection string must not be empty");
MySqlConnection conn = new MySqlConnection(connectionString);
if (conn != null)
{
conn.Open();
return conn;
}
else throw new Exception("Failed to open connection");
}
catch(MySqlException mex)
{
Log.Error(Tags.LogTag, string.Format("Exception caught while {0}. \nMessage = {1}\nStack: {2}", "creating open connection", mex.Message, mex.StackTrace));
return null;
}
catch(InvalidOperationException ioe)
{
Log.Error(Tags.LogTag, string.Format("Exception caught while {0}. \nMessage = {1}\nStack: {2}", "creating open connection", ioe.Message, ioe.StackTrace));
return null;
}
catch (Exception thisEx)
{
Log.Error(Tags.LogTag, string.Format("Exception caught while creating open connection. Message = {0}", thisEx.Message));
return null;
}
}
调试时,当执行行 conn.Open();
时,调试停止并且应用程序立即关闭,不会引发或捕获任何异常,Visual Studio 中也不会显示任何消息。当应用程序进入无限循环时会发生这种行为,但事实并非如此。
如果有帮助,Visual Studio 输出窗口会显示以下内容:
=================================================================
Native Crash Reporting
=================================================================
Got a SIGSEGV while executing native code. This usually indicates
a fatal error in the mono runtime or one of the native libraries
used by your application.
=================================================================
=================================================================
Basic Fault Adddress Reporting
=================================================================
Memory around native instruction pointer (0x766300b678):0x766300b668 00 1c 40 b9 c0 03 5f d6 fd 7b bf a9 fd 03 00 91 ..@..._..{......
0x766300b678 08 20 40 b9 a8 00 c8 37 88 01 e0 37 00 00 40 f9 . @....7...7..@.
0x766300b688 fd 7b c1 a8 c0 03 5f d6 60 08 00 b0 01 0a 00 f0 .{...._.`.......
0x766300b698 03 0a 00 f0 00 24 06 91 21 80 08 91 63 8c 0a 91 .....$..!...c...
No native Android stacktrace (see debuggerd output).
=================================================================
Managed Stacktrace:
=================================================================
at <unknown> <0xffffffff>
at System.Threading._ThreadPoolWaitCallback:PerformWaitCallback <0x00007>
at <Module>:runtime_invoke_bool <0x0006f>
=================================================================
当应用程序崩溃时,Logcat 会显示此内容:
06-01 19:22:02.091: E/mono-rt(26412): /proc/self/maps:
06-01 19:22:02.091: E/mono-rt(26412): 12c00000-13640000 rw-p 00000000 00:04 52628 /dev/ashmem/dalvik-main space (region space) (deleted)
06-01 19:22:02.091: E/mono-rt(26412): 13640000-13f40000 ---p 00a40000 00:04 52628 /dev/ashmem/dalvik-main space (region space) (deleted)
06-01 19:22:02.091: E/mono-rt(26412): 13f40000-1b200000 rw-p 01340000 00:04 52628 /dev/ashmem/dalvik-main space (region space) (deleted)
06-01 19:22:02.091: E/mono-rt(26412): 1b200000-1b240000 ---p 08600000 00:04 52628 /dev/ashmem/dalvik-main space (region space) (deleted)
06-01 19:22:02.091: E/mono-rt(26412): 1b240000-2ac00000 rw-p 08640000 00:04 52628 /dev/ashmem/dalvik-main space (region space) (deleted)
06-01 19:22:02.091: E/mono-rt(26412): 70d51000-70d64000 rw-p 00000000 fc:01 548870 /data/dalvik-cache/arm64/system@framework@boot.art
06-01 19:22:02.091: E/mono-rt(26412): 70d64000-70d66000 r--p 00013000 fc:01 548870 /data/dalvik-cache/arm64/system@framework@boot.art
06-01 19:22:02.091: E/mono-rt(26412): 70d66000-70d72000 rw-p 00000000 fc:01 548876 /data/dalvik-cache/arm64/system@framework@boot-qcom.fmradio.art
06-01 19:22:02.091: E/mono-rt(26412): 70d72000-70d73000 r--p 0000c000 fc:01 548876 /data/dalvik-cache/arm64/system@framework@boot-qcom.fmradio.art
06-01 19:22:02.091: E/mono-rt(26412): 70d73000-70d74000 rw-p 00000000 fc:01 548879 /data/dalvik-cache/arm64/system@framework@boot-com.qualcomm.qti.camera.art
06-01 19:22:02.091: E/mono-rt(26412): 70d74000-70d75000 r--p 00001000 fc:01 548879 /data/dalvik-cache/arm64/system@framework@boot-com.qualcomm.qti.camera.art
06-01 19:22:02.091: E/mono-rt(26412): 70d75000-70d77000 rw-p 00000000 fc:01 548885 /data/dalvik-cache/arm64/system@framework@boot-QPerformance.art
06-01 19:22:02.091: E/mono-rt(26412): 70d77000-70d78000 r--p 00002000 fc:01 548885 /data/dalvik-cache/arm64/system@framework@boot-QPerformance.art
06-01 19:22:02.091: E/mono-rt(26412): 70d78000-70d79000 rw-p 00000000 fc:01 548891 /data/dalvik-cache/arm64/system@framework@boot-UxPerformance.art
06-01 19:22:02.091: E/mono-rt(26412): 70d79000-70d7a000 r--p 00001000 fc:01 548891 /data/dalvik-cache/arm64/system@framework@boot-UxPerformance.art
06-01 19:22:02.091: E/mono-rt(26412): 70d7a000-71104000 rw-p 00000000 fc:01 548900 /data/dalvik-cache/arm64/system@framework@boot-core-oj.art
06-01 19:22:02.091: E/mono-rt(26412): 71104000-71118000 r--p 0038a000 fc:01 548900 /data/dalvik-cache/arm64/system@framework@boot-core-oj.art
06-01 19:22:02.091: E/mono-rt(26412): 71118000-712d2000 rw-p 00000000 fc:01 548909 /data/dalvik-cache/arm64/system@framework@boot-core-libart.art
06-01 19:22:02.091: E/mono-rt(26412): 712d2000-712e4000 r--p 001ba000 fc:01 548909 /data/dalvik-cache/arm64/system@framework@boot-core-libart.art
06-01 19:22:02.091: E/mono-rt(26412): 712e4000-71330000 rw-p 00000000 fc:01 548915 /data/dalvik-cache/arm64/system@framework@boot-conscrypt.art
06-01 19:22:02.091: E/mono-rt(26412): 71330000-71333000 r--p 0004c000 fc:01 548915 /data/dalvik-cache/arm64/system@framework@boot-conscrypt.art
06-01 19:22:02.091: E/mono-rt(26412): 71333000-7137a000 rw-p 00000000 fc:01 548918 /data/dalvik-cache/arm64/system@framework@boot-okhttp.art
06-01 19:22:02.091: E/mono-rt(26412): 7137a000-7137d000 r--p 00047000 fc:01 548918 /data/dalvik-cache/arm64/system@framework@boot-okhttp.art
06-01 19:22:02.091: E/mono-rt(26412): 7137d000-713fe000 rw-p 00000000 fc:01 548927 /data/dalvik-cache/arm64/system@framework@boot-bouncycastle.art
06-01 19:22:02.091: E/mono-rt(26412): 713fe000-71405000 r--p 00081000 fc:01 548927 /data/dalvik-cache/arm64/system@framework@boot-bouncycastle.art
06-01 19:22:02.092: A/libc(26412): Fatal signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x20 in tid 26472 (Thread Pool Wor), pid 26412 (.keeptravelling)
06-01 19:22:02.182: E/DEBUG(26707): failed to readlink /proc/26472/fd/115: No such file or directory
06-01 19:22:02.268: W/crash_dump64(26707): failed to attach to thread 26702: No such process
06-01 19:22:02.268: E/crash_dump64(26707): failed to interrupt 26702 to detach: No such process
06-01 19:22:02.268: W/crash_dump64(26707): failed to ptrace interrupt thread 26702: No such process
06-01 19:22:02.292: E/WakeLock(15163): GCM_HB_ALARM release without a matched acquire!
06-01 19:22:02.292: W/WakeLock(15163): GCM_HB_ALARM counter does not exist
06-01 19:22:02.294: E/WakeLock(15163): GCM_CONN_ALARM release without a matched acquire!
06-01 19:22:02.311: I/crash_dump64(26707): obtaining output fd from tombstoned, type: kDebuggerdTombstone
06-01 19:22:02.317: I//system/bin/tombstoned(2430): received crash request for pid 26472
06-01 19:22:02.319: I/crash_dump64(26707): performing dump of process 26412 (target tid = 26472)
06-01 19:22:02.324: D/SharedPreferencesImpl(26412): Time required to fsync /data/user/0/fib.smascaro.keeptravelling/shared_prefs/com.google.android.gms.measurement.prefs.xml: [<1: 0, <2: 0, <4: 1, <8: 1, <16: 0, <32: 0, <64: 0, <128: 0, <256: 1, <512: 1, <1024: 0, <2048: 0, <4096: 0, <8192: 0, <16384: 0, >=16384: 0]
06-01 19:22:02.338: A/DEBUG(26707): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
06-01 19:22:02.338: A/DEBUG(26707): Build fingerprint: 'xiaomi/tissot/tissot_sprout:9/PKQ1.180917.001/V10.0.9.0.PDHMIXM:user/release-keys'
06-01 19:22:02.338: A/DEBUG(26707): Revision: '0'
06-01 19:22:02.338: A/DEBUG(26707): ABI: 'arm64'
06-01 19:22:02.338: A/DEBUG(26707): pid: 26412, tid: 26472, name: Thread Pool Wor >>> fib.smascaro.keeptravelling <<<
06-01 19:22:02.338: A/DEBUG(26707): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x20
06-01 19:22:02.338: A/DEBUG(26707): Cause: null pointer dereference
06-01 19:22:02.338: A/DEBUG(26707): x0 0000000000000000 x1 0000000000000000 x2 0000000000000000 x3 00000076573f38b0
06-01 19:22:02.338: A/DEBUG(26707): x4 0000007657e9e9a0 x5 00000076573f3940 x6 0000000000000000 x7 0000000000000000
06-01 19:22:02.338: A/DEBUG(26707): x8 0000000000000000 x9 0000000000000000 x10 0000000000000000 x11 0000000000000000
06-01 19:22:02.338: A/DEBUG(26707): x12 0000000000000000 x13 0000000000000000 x14 0000000000000000 x15 aaaaaaaaaaaaaaab
06-01 19:22:02.338: A/DEBUG(26707): x16 00000076631e41f8 x17 000000766300b670 x18 00000076580837c8 x19 00000076631fb560
06-01 19:22:02.338: A/DEBUG(26707): x20 0000000000000002 x21 0000000000000000 x22 0000000000000002 x23 0000000000000076
06-01 19:22:02.339: A/DEBUG(26707): x24 0000000000000000 x25 0000000000000000 x26 00000076573f3a30 x27 0000007653af07d8
06-01 19:22:02.339: A/DEBUG(26707): x28 0000007657e9e000 x29 00000076573f2d50
06-01 19:22:02.339: A/DEBUG(26707): sp 00000076573f2d50 lr 0000007662f52658 pc 000000766300b678
06-01 19:22:02.340: A/DEBUG(26707): backtrace:
06-01 19:22:02.340: A/DEBUG(26707): #00 pc 0000000000177678 /data/app/fib.smascaro.keeptravelling-gmskKOoZ0XLx3XQnXfD0Dw==/lib/arm64/libmonosgen-2.0.so (mono_jit_info_get_method+8)
欢迎任何帮助。
谢谢。
编辑:添加了 logcat 输出
最佳答案
最后,在面对这个问题几周后,发现这是一个 Mono.Android 错误。
为了解决这个问题,我将Xamarin.Android SDK更新到9.3.0.23,不是稳定版本或官方版本,但请引用this Github 提交了问题。
链接位于 this comment .
关于c# - 无法捕获 MySqlConnection Open(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56408332/
多个 ChildException catch block 和一个 Exception catch block 之间哪个更好? 更好,我的意思是以良好的实践方式。 举例说明: public stati
我正在尝试将脱机计算机记录在文本文件中,以便以后可以再次运行它们。似乎没有被记录或捕获。 function Get-ComputerNameChange { [CmdletBinding()]
我正在将 Scala 'try/catch' 测试代码转换为使用 'intercept' 有没有我不应该使用“拦截”的场景?使用 'intercept' 而不是 'try/catch' 的唯一好处是简
我对erlang很陌生,我正在尝试使用基本的try/catch语句来工作。我正在使用Webmachine处理一些请求,我真正想做的就是解析一些JSON数据并将其返回。如果JSON数据无效,我只想返回一
我不知道如何捕获删除按键。我发现在 ASCII 代码表中,它位于 127 位,但是 if (Key = #127) then 却无济于事。 然后我检查了 VK_DELETE 的值,它是 47。尝试使用
我很少在失败时对数据库查询使用唯一的错误消息 我经常使用简短的标准消息,例如“数据库错误/失败。请与网站管理员联系”或类似的消息。或自动发送给我 我正在寻找一种在PDO中全局设置一次try {}和ca
我有一个变量CompletableFuture completableFuture 。我希望能够使用任何类型的对象来完成它。例如:completableFuture.complete(new Stri
我认为这是基本的东西,但我不知道该怎么做。为什么我得到 IOException never throw in body of相应的 try 语句 public static void main(Str
我在此代码中遇到 JSON 异常: JSONObject jObject = new JSONObject(JSONString); pontosUsuario.setIdUsuari
我正在尝试打印出用单引号括起来的文本。 /bin/bash -lc '/home/CASPER_REPORTS/scripts/CASPER_gen_report.sh CASPER_1' /bin/
我这里遇到了一点问题。我想弄清楚如何捕获 IllegalArgumentException。对于我的程序,如果用户输入负整数,程序应该捕获 IllegalArgumentException 并询问用户
我无法理解 EJBTransactionRolledbackException。 我有实体: @Entity public class MyEntity { @Id @Generate
对于我给自己提出的以下挑战,如果社区的经验给我任何建议,我将不胜感激 - 即,这里有任何关于最佳方法/方向的指示吗? 要求 允许收集/实时监控从用户 Windows PC 到一组特定 IP 地址(或
我想在我的 ABAP 代码中捕获并处理 SAPSQL_DATA_LOSS。 我试过这个: try. SELECT * FROM (rtab_name) AS rtab
我知道捕获错误不是一个好的做法,但在这种情况下,这样做很重要。我正在尝试运行一个包含游戏一部分的 jar,但它给了我一个 unsatisfiedlink 错误,但这是有趣的部分:我正在使用这段代码:
我有一个表单页面,当我保存它时,它会覆盖数据库。表单页面中有一个文本框,允许用户输入 4000 个字符,但如果用户输入的字符超过此值,则会出现以下错误: ERROR 15:54:05 Abstrac
我想知道在python中绑定(bind)键的最简单方法 例如,默认的 python 控制台窗口出现并等待,然后在 psuedo -> if key "Y" is pressed: print (
下面是别人写的类。 我面临的问题是,当它进入parse method时与 null as the rawString ,它正在扔NumberFormatException 。 所以我想做的是,我应该捕
我有一个简单的脚本,可以捕获所有鼠标单击,除非您单击实际有效的内容。链接、Flash 视频等。我如何调整它,以便无论用户点击什么,在视频加载、新页面加载等之前,它都会发送我构建的简单 GET 请求?
我有一个带有一些选择列表的表单,当选择某些值时,这些列表将显示/隐藏更多输入字段。 问题是大多数用户都是数据输入人员,因此他们在输入数据时大量使用键盘,并且选择列表的 change 事件仅在焦点离开输
我是一名优秀的程序员,十分优秀!