我有一个UWP应用程序,我试图在其中存储和检索本地文本文件中的某些数据,但是无论我如何尝试,应用程序都陷入僵局。由于需要进行同步操作,因此我尝试使用任务并等待其完成,但是应用程序锁定了。

我的UWP应用程序中有一个名为“ MainPage”的页面,在其构造函数中,我具有以下代码:

var listenkeyViewModel = new ListenkeyViewModel();
listenkeyViewModel.GetKey();
listenkey = listenkeyViewModel.Listenkey;


get密钥是这里的问题,因为它在ViewModel上调用了一个方法(我创建该方法是同步的,因为我认为最好尽快进行同步调用。

public void GetKey()
{
    try
    {
        var listenKeyTask = RetrieveListenKey();
        _listenkey = listenKeyTask.Result;
    }
    catch (Exception e)
    {
    }
}

public static async Task<string> RetrieveListenKey()
{
    try
    {
        var storageFolder = Windows.Storage.ApplicationData.Current.LocalFolder;
        var listenkeyFile = await storageFolder.GetFileAsync("listenkey.txt");
        return await Windows.Storage.FileIO.ReadTextAsync(listenkeyFile);
    }
    catch (Exception e)
    {
        throw new Exception("Could not load file");
    }
}


我知道事情是“一直异步的”,但这在这里是不可能的。我无法使原始代码所在的构造函数异步。您应该如何避免陷入僵局?我不明白。

最佳答案

GetKey转换为异步/等待

public async Task GetKey() {
    try {
        var listenKeyTask = RetrieveListenKey();
        _listenkey = await listenKeyTask;
    } catch (Exception e) {
        //...should handle/log error
    }
}


将此调用移出构造函数,然后移入事件处理程序。例如页面加载或在页面生命周期的早期调用的其他事件。

partial class MainPage : Page {
    ListenkeyViewModel listenkeyViewModel;
    string listenkey;

    public MainPage() {
        InitializeComponent();
        listenkeyViewModel = new ListenkeyViewModel();
        // add a handler to be called when the page has been loaded
        this.Loaded += OnPageLoaded;
    }

    async void OnPageLoaded(object sender, RoutedEventArgs e) {
        await listenkeyViewModel.GetKey();
        listenkey = listenkeyViewModel.Listenkey;
    }

    // Shown for demonstration purposes only.
    // This is typically autogenerated by Visual Studio.
    private void InitializeComponent() {
    }
}


在事件处理程序上允许使用async void,因此这应允许流程流畅进行而不会发生死锁。

关于c# - 如何解决这个僵局?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43964613/

10-11 15:21