[vtk-developers] Weak pointers and thread safety
Will Schroeder
will.schroeder at kitware.com
Tue Oct 12 06:31:51 EDT 2010
How would this impact performance? Would it improve it do you think?
W
On Mon, Oct 11, 2010 at 10:35 PM, David Gobbi <david.gobbi at gmail.com> wrote:
> Hi All,
>
> The VTK weak pointer implementation is not thread safe because it can
> be used just like a regular pointer, even though the object itself
> might be deleted by a separate thread at any time.
>
> By comparison, "safe" weak pointer like in boost and Qt cannot be used
> in place of ordinary pointers. Instead, in order to use them their
> "GetPointer()"-like methods increment the reference count and then
> return a smart pointer, which is guaranteed to be valid until it goes
> out of scope:
>
> vtkSmartPointer<SomeClass> smartPtr = weakPtr.GetPointer();
> if (smartPtr.GetPointer() != 0)
> {
> // do something with smartPtr
> }
> // reference count decremented when smartPtr goes out of scope
>
> Because VTK's vtkWeakPointer::GetPointer() does not return a smart
> pointer or do any thread locking, thread-safe use of vtkWeakPointer
> requires the following:
>
> vtkSimpleCriticalSection critSec;
> critSec.Lock();
> vtkSmartPointer<SomeClass> smartPtr = weakPtr.GetPointer();
> critSec.Unlock();
> if (smartPtr.GetPointer() != 0)
> {
> // do something with smartPtr
> }
>
> If weakPtr.GetPointer() was changed to return a smart pointer, then it
> could do the locking internally. This change would be mostly, but not
> completely, backwards compatible. What do people think?
>
> David
> _______________________________________________
> Powered by www.kitware.com
>
> Visit other Kitware open-source projects at
> http://www.kitware.com/opensource/opensource.html
>
> Follow this link to subscribe/unsubscribe:
> http://www.vtk.org/mailman/listinfo/vtk-developers
>
>
--
William J. Schroeder, PhD
Kitware, Inc.
28 Corporate Drive
Clifton Park, NY 12065
will.schroeder at kitware.com
http://www.kitware.com
(518) 881-4902
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://public.kitware.com/pipermail/vtk-developers/attachments/20101012/12adac88/attachment.html>
More information about the vtk-developers
mailing list