2

我正在制作一个 Windows Phone 8 应用程序。此应用程序的一部分需要保存状态。我将它保存为一串Json。如果我打开应用程序,保存一些数据,退出应用程序并再次加载它,它会挂在 GetFolderAsync 或 OpenStreamForReadAsync 上。它不会每次都发生,但是一旦它开始挂起,我必须杀死整个模拟器并制作一个新的模拟器才能再次启动应用程序。

我什至尝试过只制作一个没有数据的空文件,但问题仍然存在。

下面是我用来保存和加载数据的代码。无论是在应用程序启动时还是在表单加载时,我在哪里调用数据加载都没有关系,它仍然会中断。

    private async Task SaveLists()
    {
        //XmlSerializer serializer = new XmlSerializer(typeof(ListHolder));

        // Get the local folder.
        StorageFolder local = Windows.Storage.ApplicationData.Current.LocalFolder;

        // Create a new folder name DataFolder.
        var dataFolder = await local.CreateFolderAsync("DataFolder",
            CreationCollisionOption.OpenIfExists);

        // Create a new file named DataFile.txt.
        var file = await dataFolder.CreateFileAsync("Lists.json",
        CreationCollisionOption.ReplaceExisting);

        string json = JsonConvert.SerializeObject(Lists, Formatting.Indented);
        byte[] fileBytes = System.Text.Encoding.UTF8.GetBytes(json.ToCharArray());

        using (var s = await file.OpenStreamForWriteAsync())
        {
            s.Write(fileBytes, 0, fileBytes.Length);

        }
    }



    private async Task LoadLists()
    {


        // Get the local folder.
        StorageFolder local = Windows.Storage.ApplicationData.Current.LocalFolder;

        if (local != null)
        {
            try
            {
                // Get the DataFolder folder.

                var dataFolder = await local.GetFolderAsync("DataFolder");

                // Get the file.
                var files = dataFolder.GetFilesAsync();
                var file = await dataFolder.OpenStreamForReadAsync("Lists.json");

                string jsonString = "";
                // Read the data.
                using (StreamReader streamReader = new StreamReader(file))
                {
                    jsonString = streamReader.ReadToEnd();
                }
                if (jsonString.Length > 0)
                {
                    Lists = JsonConvert.DeserializeObject<List<ItemList>>(jsonString);
                }    
                else
                {
                    Lists = new List<ItemList>();
                }                
            }
            catch (Exception ex)
            {
                Lists = new List<ItemList>();
            }

        }
    }
4

1 回答 1

2

您通过调用Result. 我在我的博客最近的 MSDN 文章中解释了这个死锁。总之,await将(默认情况下)尝试在上下文中恢复执行(当前SynchronizationContext的,除非它是null,在这种情况下它使用当前的TaskScheduler)。

在您的情况下,当前SynchronizationContext是 UI 上下文,仅由 UI 线程使用。因此,当您通过调用阻塞 UI 线程时Result,该async方法无法调度回 UI 线程完成。

于 2013-06-08T15:39:10.530 回答