I have a TextBox that’s bound to a property that gets modified at a very rapid rate in a background thread. Is data binding in WPF thread safe? Will the data in the property or the TextBox ever get out of sync? Is it necessary (or even possible) to use synchronization on a property that takes part in data binding?
I understand that, if the class on which the property resides implements INotifyPropertyChanged, the binding framework automatically marshalls the UI update to the UI thread. However, doesn’t that still allow the data to get out of sync? If I understand correctly, variables that are written from one thread and read from another should by synchronized… is data binding an exception?
thanks!!
Yes, for the most part. Binding is thread safe for single objects (so should be fine for your string). However, binding to a collection is not thread safe – and still requires manually marshaling. If you have a control bound to a collection, you cannot change the collection on a background thread.
This shouldn’t get out of sync, unless multiple threads are writing to the variable very quickly (in which case, they’ll all block until they get back in sync, but there is a period of time where threads will “wait” on the UI). The marshaling happens synchronously, so the thread doesn’t receive values until the binding is up to date. This can slow down your processing, as the UI update has to happen before your background thread can continue.