diff options
| author | 2014-12-12 21:04:39 +0000 | |
|---|---|---|
| committer | 2014-12-12 21:04:40 +0000 | |
| commit | d1512fed4e43bba77fb21fd1b6322c22ef7c5881 (patch) | |
| tree | 54b30694887adef8abb9df4b11b981fd5f8d7621 /runtime/gc/reference_queue.cc | |
| parent | f51890d06267da1739ef5f699a8b746e0c432463 (diff) | |
| parent | 9e2094f921b63582e84d65849b1c5c6dc4d22b44 (diff) | |
Merge "Add ReferenceQueue test"
Diffstat (limited to 'runtime/gc/reference_queue.cc')
| -rw-r--r-- | runtime/gc/reference_queue.cc | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/runtime/gc/reference_queue.cc b/runtime/gc/reference_queue.cc index 4003524e5e..f4efe3c823 100644 --- a/runtime/gc/reference_queue.cc +++ b/runtime/gc/reference_queue.cc @@ -91,15 +91,30 @@ mirror::Reference* ReferenceQueue::DequeuePendingReference() { void ReferenceQueue::Dump(std::ostream& os) const { mirror::Reference* cur = list_; os << "Reference starting at list_=" << list_ << "\n"; - while (cur != nullptr) { + if (cur == nullptr) { + return; + } + do { mirror::Reference* pending_next = cur->GetPendingNext(); - os << "PendingNext=" << pending_next; + os << "Reference= " << cur << " PendingNext=" << pending_next; if (cur->IsFinalizerReferenceInstance()) { os << " Zombie=" << cur->AsFinalizerReference()->GetZombie(); } os << "\n"; cur = pending_next; + } while (cur != list_); +} + +size_t ReferenceQueue::GetLength() const { + size_t count = 0; + mirror::Reference* cur = list_; + if (cur != nullptr) { + do { + ++count; + cur = cur->GetPendingNext(); + } while (cur != list_); } + return count; } void ReferenceQueue::ClearWhiteReferences(ReferenceQueue* cleared_references, |