Trying to follow the hints laid out here, but she doesn't mention how to handle it when your collection needs to return a value, like so:
private delegate TValue DequeueDelegate();
public virtual TValue Dequeue()
{
if (dispatcher.CheckAccess())
{
--count;
var pair = dict.First();
var queue = pair.Value;
var val = queue.Dequeue();
if (queue.Count == 0) dict.Remove(pair.Key);
OnCollectionChanged(new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Remove, val));
return val;
}
else
{
dispatcher.BeginInvoke(new DequeueDelegate(Dequeue));
}
}
This obviously won't work, because dispatcher.BeginInvoke
doesn't return anything. What am I supposed to do?
Call Invoke
in place of BeginInvoke
. This will run it on the dispatcher's thread, but will execute synchronously and return the result returned by the delegate.
If you don't need the result immediately, hold onto the DispatcherOperation
returned by BeginInvoke
. When you do need the result, call the operation's Wait
method and, if it returns DispatcherOperationStatus.Completed
, read the Result
property.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With