【问题标题】:Application is not responding upon receipt data from SQLite Database MAUI应用程序在收到来自 SQLite 数据库 MAUI 的数据后没有响应
【发布时间】:2022-11-11 21:35:35
【问题描述】:

我正在尝试用数据库中的组件填充ListView。当我尝试打开页面时,应用程序冻结并显示错误"Application is not responding",所以,我不知道为什么会发生这种情况,因为日志没有任何异常。

ContentPage,我尝试在其中获取数据:

public PollsPage()
    {
        InitializeComponent();
        getPolls();
        
    }

    public async Task getPolls()
    {
        Database.SmartYardDB db = new Database.SmartYardDB();
        if(db.getNotAnsweredPolls().Result != null)
            lvPolls.ItemsSource = (IList<Models.Tables.Polls>)db.getNotAnsweredPolls().Result;
    }

来自数据库类的方法getNotAnsweredPolls

public SQLiteAsyncConnection db;

        public async Task init()
        {
            if (db is not null)
            {
                return;
            }

            db = new SQLiteAsyncConnection(Constants.Database.DatabasePath, Constants.Database.Flags);
            await db.CreateTableAsync<Models.Tables.Users>();
            await db.CreateTableAsync<Models.Tables.Messages>();
            await db.CreateTableAsync<Models.Tables.Polls>();
        }

public async Task<List<Models.Tables.Polls>> getNotAnsweredPolls()
        {
            await init();
            return await db.Table<Models.Tables.Polls>().Where(
                x => x.userAnswer != Constants.Database.POLLS_USERANSWER_NOTANSWERED &&
                x.status == Constants.Database.POLLS_STATUS_ACTIVE).ToListAsync();

        }

我如何走数据库的路径:

public static string DatabasePath =>
        Path.Combine(FileSystem.AppDataDirectory, DB_NAME);

安卓清单:

<manifest xmlns:android="http://schemas.android.com/apk/res/android">
    <application android:allowBackup="true" android:icon="@mipmap/appicon" android:roundIcon="@mipmap/appicon_round" android:supportsRtl="true"></application>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" />
</manifest>

【问题讨论】:

  • 不要从构造函数中调用async 方法。您可以使用OnAppearing 来代替

标签: c# sqlite maui


【解决方案1】:

网络和数据库工作应该在单独的线程中完成,而 UI 是初始化和响应式的。如果您预计这项工作需要很长时间才能完成,您还应该确保用户可以随意取消这些。

用户应该看到“正在获取数据...”、一些活动指示器旋转、取消/重试按钮等,而不是冻结的灰显屏幕。

您的页面(视图)负责显示用户界面。让它发挥作用。之后覆盖事件(甚至更好 - 将它们绑定到 ViewModel)并在那里处理后台工作。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-07-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-03-25
    • 1970-01-01
    相关资源
    最近更新 更多