- 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/
这是我在 Visual Studio 中连接到 Unity3d 的代码: public void SetupSQLConnection() { Debug.Log("Connection Fu
当我将我的应用程序上传到服务器进行测试时,我遇到了这个奇怪的莫名其妙的错误。我查了一下,好像是MySql.Data冲突导致的,我上传的副本是:6.3.7.0。 我该如何解决这个问题?我以为只要将它放入
从 OleDB 更改为 MySqlConnect 后,我遇到了 ExecuteNonQuery 在 UPDATE sql 中抛出错误的问题 - 现有代码工作正常,使用提交的 OleDB 行更新访问
我是 vb.net 和 mysql 的新手。 当我将 Dim SQLConnection 定义为 MySqlConnection = New MySqlConnection 时,我感到很困惑。 它说新
我看过一个使用MySqlConnection变量名称= new MySqlConnection(connection string);的教程 但是当我在 Visual Studio Express 2
我是 php 语法的新手,正在寻找有关创建最可接受或最正确代码的建议。我专注于前端设计,但我喜欢确保我的代码是正确的。我在一个数字媒体项目中,我的导师给了我们这个连接到我们的 MYSQL 数据库的代码
如果 MySQL 连接的 CertificatePassword 或 CertificateFile 不正确,则会导致我的应用程序崩溃。这是一个问题的原因是用户是输入连接信息的人。这意味着,如果他们输
我有一个应用程序可以触发 mysql 命令(查询)“显示数据库”,查询有效并正确返回,但我无法关闭连接。我使用的用户同时允许 24 个连接,因此问题在我的程序中进一步弹出,但将允许的连接减少到 2 表
我正在从 C# 应用程序查询。我可以这样做: MySqlConnection conn = new MySqlConnection(conString); conn.Open(); //do data
我试图在主窗体中打开一个 MySQL 连接。但是,O 在尝试以其他形式使用连接时遇到了问题。 我应该如何设置才能在整个程序中只需要打开一次连接,并使用同一个连接从数据库中获取数据。 或者我应该在每个表
我刚开始使用异步和任务,我的代码已停止处理。当我有一个传入的网络数据包并且我尝试与数据包处理程序内的数据库进行通信时,就会发生这种情况。 public class ClientConnectedPac
我用 Hangfire 创建了一个 RecurringJob,但是当这个工作完成时我得到了以下错误: ERROR 2018-12-05 15:20:05,982 [fc937] Hangfire.Au
这是我的 Mysql 类: public class MysqlConnection { public Connection MysqlConnect() { String u
我正在创建一个连接到 SQL 数据库的桌面应用程序。由于某种原因,我在连接到数据库时遇到问题,连接无限期地挂起,而没有给出错误(没有像应有的超时)。我的数据库使用 XAMPP。我在谷歌上广泛搜索了这个
我目前正在开发游戏服务器,它使用 MySQL 进行存储。 问题是:如果我将 MySQL 连接保持空闲状态,我认为这会导致它超时? 如果是,关闭连接空闲超时是否明智且可能?或者也许我应该在每次查询之前检
我正在开发 Xamarin.Android 应用程序,并且正在使用远程 MySql 数据库 (AWS)。连接工作得很好,没有任何问题。但是当用户没有连接(使用飞行模式测试)时,它会崩溃,我无法捕捉到它
我正在尝试创建一个函数来检查是否选中了复选框,如果选中,则返回新的 MySqlConnection,否则返回不同 MySqlConnection 的值。其实应该很简单,但我没有办法让它工作。 当我在没
我在 AWS 上托管一个 Aurora MySql 实例,并尝试通过 Lambda 函数从中读取表。 这是我的连接字符串: Server=xxx.xxx.xxx4.xxx; port=3306; da
我的类库无法使用 MySql .net 连接器建立 mysql 连接。如果我通过使用类库的命令行控制台应用程序运行它,它可以连接。但当我使用 PHP COM 加载/运行 .net 程序集时,它失败了。
我将 Max Pool Size=50 添加到连接字符串中。这似乎没有帮助。 我收到一个错误dreamhost2.vshost.exe 错误:0:用户 gensurv_general 已拥有超过“ma
我是一名优秀的程序员,十分优秀!