开发者

Silverlight and problems with async call

开发者 https://www.devze.com 2022-12-22 11:47 出处:网络
I have some code that works as follows: App.xaml calls a SetUp() method which populates a local collection using async calls and exposes the collection as a public property.

I have some code that works as follows:

App.xaml calls a SetUp() method which populates a local collection using async calls and exposes the collection as a public property.

That's all good.

Now I make an instance of the first page in my Silverlight app like so

    private void Application_Startup(object sender, StartupEventArgs e)
    {
        this.RootVisual = new Summary();
    }

In the constructor of Summary() I expect those async calls to have been complete and my collection开发者_StackOverflow中文版 to be filled but the async calls have not yet complete. Even if I do a Thread.Sleep(100000....) before i make an instance on Summary() this is the case

And the thing is that until the constructor of Summary() is exited and the UI displayed to the user my async calls do not get kicked off!

What!!!

Is there anything I can do about that or is that just the way asyn calls work i.e. they wait until the current until of work finished before firing?


This is how I work round this situation (I'll use simple string download as an example):-

private void Application_Startup(object sender, StartupEventArgs e)
{
    WebClient web = new WebClient();
    web.DownloadStringCompleted += (s, args) =>
    {
        // Do stuff with args.Result);
        this.RootVisual = new Summary();
    };
    web.DownloadStringAsync(new Uri("SomeUrl.txt", UriKind.Relative));
}

Note that the construction of Summary and the assignment to RootVisual are defered until the asynchronous download is complete.


Silverlight was specifically designed to not have any blocking operations -- that's why you have to do async in the first place. What you really have to do is make your app run properly while waiting for the async completion handler to execute.


This is by design. The alternative would be that the user has to wait longer before he sees anything at all.

If you really want to prevent showing an incomplete summery then first shown another page with 'waiting' or a progress bar. Fire the async events from that page or its parent. Then show the Summary when the async call returns.

To deal with an incomplete Summary you might want to use ICommand


I know this is an old thread, but for all following reader i want to provide my experience with a similar problem. If i understood you correctly - the reason why your async calls do not complete is because you block the main thread. I ran into the same problem, if you block the main thread none of the other threads continue. The solution was to do the async calls inside a backgroundworker and show, like pauldendulk said, a waiting - page. Use Debug.WriteLine() to monitor the process in the output.

0

精彩评论

暂无评论...
验证码 换一张
取 消