【发布时间】: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来代替