Xamarin-Sqlite.net的内存消耗非常高

问题描述

我正在使用Xamarin.Android应用程序。在此应用程序中,我有本地数据库。我正在使用sqlite.net插件来管理sqlite操作。

虽然在较低配置下测试应用程序,但我发现应用程序占用了内存。在使用Xamarin Profiler进行检查时,我知道多数内存已分配给一种数据库方法[超过50%]。

它在System.Linq.Enumerable:FirstofDefault<sqlite.TableMapping/Column>中使用。

我们可以手动释放此内存吗?有什么办法吗?我们可以通过编程方式从应用程序释放内存吗?

我尝试过使用GC.Collect(),但是它没有用。

如果有人知道这个问题背后的实际原因?

解决方法

经过研究,我发现我们可以使用PRAGMA函数来释放内存。

我们可以调用以下查询来手动释放内存。

PRAGMA shrink_memory;