diff options
author | Noel Grandin <noel@peralex.com> | 2016-05-24 15:10:36 +0200 |
---|---|---|
committer | Michael Stahl <mstahl@redhat.com> | 2016-05-24 19:46:06 +0000 |
commit | 6c419129f27d61295508d14448351f62e994806b (patch) | |
tree | 31bd4a0fbb00edadc7bad0da053de357152b56a5 /cppuhelper/source | |
parent | 019e3cb1c37d74bf389b04ed9102259bdc28193e (diff) |
optimise references list handling in OWeakConnectionPoint some more
After my commit 1e063e8b "optimise references list handling in
OWeakConnectionPoint"
Reduce scope of locking, and copy a the performance trick from
OInterfaceContainerHelper.
Change-Id: Idc218e9d4edf45f8c37c7e517d1a26821800448b
Reviewed-on: https://gerrit.libreoffice.org/25406
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Michael Stahl <mstahl@redhat.com>
Diffstat (limited to 'cppuhelper/source')
-rw-r--r-- | cppuhelper/source/weak.cxx | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/cppuhelper/source/weak.cxx b/cppuhelper/source/weak.cxx index 14334259ee8c..b6abef5ebe56 100644 --- a/cppuhelper/source/weak.cxx +++ b/cppuhelper/source/weak.cxx @@ -107,12 +107,14 @@ void SAL_CALL OWeakConnectionPoint::release() throw() void SAL_CALL OWeakConnectionPoint::dispose() throw(css::uno::RuntimeException) { - MutexGuard aGuard(getWeakMutex()); - Any ex; - // other code is going to call removeReference while we are doing this, so we need a - // copy, but since we are disposing and going away, we can just take the original data std::vector<Reference<XReference>> aCopy; - aCopy.swap(m_aReferences); + { // only hold the mutex while we access the field + MutexGuard aGuard(getWeakMutex()); + // other code is going to call removeReference while we are doing this, so we need a + // copy, but since we are disposing and going away, we can just take the original data + aCopy.swap(m_aReferences); + } + Any ex; for (const Reference<XReference> & i : aCopy ) { try @@ -172,8 +174,16 @@ void SAL_CALL OWeakConnectionPoint::removeReference(const Reference< XReference throw(css::uno::RuntimeException, std::exception) { MutexGuard aGuard(getWeakMutex()); - // search from end because the thing that last added a ref is most likely to be the - // first to remove a ref + // Search from end because the thing that last added a ref is most likely to be the + // first to remove a ref. + // It's not really valid to compare the pointer directly, but it's faster. + for (auto it = m_aReferences.rbegin(); it != m_aReferences.rend(); ++it) { + if (it->get() == rRef.get()) { + m_aReferences.erase( it.base()-1 ); + return; + } + } + // interface not found, use the correct compare method auto it = std::find(m_aReferences.rbegin(), m_aReferences.rend(), rRef); if ( it != m_aReferences.rend() ) m_aReferences.erase( it.base()-1 ); |