Fix in weak_count in Arc.

In the case the weak count was locked, the weak_count function could
return usize::MAX. We need to test this condition manually.
This commit is contained in:
Jacques-Henri Jourdan 2017-07-18 19:31:22 +02:00
parent 83c659ef65
commit 49edaf14fd

View File

@ -453,7 +453,10 @@ impl<T: ?Sized> Arc<T> {
#[inline] #[inline]
#[stable(feature = "arc_counts", since = "1.15.0")] #[stable(feature = "arc_counts", since = "1.15.0")]
pub fn weak_count(this: &Self) -> usize { pub fn weak_count(this: &Self) -> usize {
this.inner().weak.load(SeqCst) - 1 let cnt = this.inner().weak.load(SeqCst);
// If the weak count is currently locked, the value of the
// count was 0 just before taking the lock.
if cnt == usize::MAX { 0 } else { cnt - 1 }
} }
/// Gets the number of strong (`Arc`) pointers to this value. /// Gets the number of strong (`Arc`) pointers to this value.