2017-04-18 07:52:04 +08:00
## BlockingCollection<T>.TryTakeFromAny does not throw anymore
2017-04-06 04:52:19 +08:00
### Scope
Minor
### Version Introduced
4.5
### Source Analyzer Status
Available
### Change Description
2017-04-21 02:19:05 +08:00
If one of the input collections is marked completed, < xref:System.Collections.Concurrent.BlockingCollection ` 1 . TryTakeFromAny ( System . Collections . Concurrent . BlockingCollection { ` 0 } [ ] , ` 0 @ ) >
no longer returns -1 and
< xref:System.Collections.Concurrent.BlockingCollection ` 1 . TakeFromAny ( System . Collections . Concurrent . BlockingCollection { ` 0 } [ ] , ` 0 @ ) >
no longer throws an exception. This change makes it possible to work with
collections when one of the collections is either empty or completed, but the
other collection still has items that can be retrieved.
2017-04-06 04:52:19 +08:00
- [ ] Quirked
- [ ] Build-time break
### Recommended Action
If TryTakeFromAny returning -1 or TakeFromAny throwing were used for control-flow purposes in cases of a blocking collection being completed, such code should now be changed to use `.Any(b => b.IsCompleted)` to detect that condition.
### Affected APIs
* ``M:System.Collections.Concurrent.BlockingCollection`1.TakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@)``
* ``M:System.Collections.Concurrent.BlockingCollection`1.TakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@,System.Threading.CancellationToken)``
* ``M:System.Collections.Concurrent.BlockingCollection`1.TryTakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@)``
* ``M:System.Collections.Concurrent.BlockingCollection`1.TryTakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@,System.Int32)``
* ``M:System.Collections.Concurrent.BlockingCollection`1.TryTakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@,System.TimeSpan)``
* ``M:System.Collections.Concurrent.BlockingCollection`1.TryTakeFromAny(System.Collections.Concurrent.BlockingCollection{`0}[],`0@,System.TimeSpan)``
### Category
Core
2017-04-18 07:52:04 +08:00
<!-- breaking change id: 18 -->