1

这可能是一个愚蠢的问题。但是当我从 Live SDK 示例中修改一个示例时,遇到了一个奇怪的问题。

我在想根本原因是异步函数 GetAll() 被同步使用。

以下是代码片段,我将问题作为注释。提前致谢!

class SkyeDriveViewModel: INotifyPropertyChanged
{
    private List<SkyDriveItem> folderList = null;
    public List<SkyDriveItem> FolderList
    {
        get { return folderList; }
        private set
        {
            if (value != folderList)
            {

                folderList = value;
                NotifyPropertyChanged("FolderList");
            }
        }
    }

    private async void GetAll(string desiredPath)
    {
        FolderList = new List<SkyDriveItem>();

        this.liveClient = new LiveConnectClient(SkyDrivePage.Session);
        try
        {
            LiveOperationResult operationResult = await this.liveClient.GetAsync(desiredPath);
            dynamic result = operationResult.Result;

            dynamic items = result.data;
            foreach (dynamic item in items)
            {
                SkyDriveItem newItem = new SkyDriveItem(item);
                if (newItem.IsFolder)
                {
                    FolderList.Add(newItem);
                }

            }

        }
        catch (LiveConnectException e)
        {
        }
        //**till here, FolderList was assigned**
    }

    public void InitList()
    {
        Debugger.Log();
        GetAll(SKYDRIVEINITPATH);
        Debugger.LogWhen(eDebugger.LogTiming.Exit); 
        //**till here, FolderList had zero item**
    }

}
4

1 回答 1

5

一般来说,有一个async void功能是一个警告信号。对于事件处理程序,您应该只有这样的方法。的适当返回类型GetAllTask,甚至可能Task<List<SkyDriveItem>>

问题是调用GetAll只会在第一次await调用之前执行代码,此时它会返回给调用者,并且方法的其余部分将异步执行。

这里的问题是,因为方法是void您无法知道何时完成。你有一个“一劳永逸”的方法,永远不知道你的清单什么时候准备好。如果GetAll返回一个任务,那么您可以await执行该任务并确保您的列表已实际填充。

于 2013-05-16T20:22:32.830 回答