diff options
author | Sean Gillespie <sean@swgillespie.me> | 2017-04-22 04:39:09 -0700 |
---|---|---|
committer | Jan Kotas <jkotas@microsoft.com> | 2017-04-22 04:39:09 -0700 |
commit | 02fa8ca0932d02ce369f6a7405128ab5b729fb8d (patch) | |
tree | 29c8e81965ce96a2358245025cdbf5233005defc | |
parent | ea25e8d23626f1f5734016e7c9acb83546688a8e (diff) | |
download | coreclr-02fa8ca0932d02ce369f6a7405128ab5b729fb8d.tar.gz coreclr-02fa8ca0932d02ce369f6a7405128ab5b729fb8d.tar.bz2 coreclr-02fa8ca0932d02ce369f6a7405128ab5b729fb8d.zip |
Remove destructor from GCEvent and instead rely on the OS to clean up (#11132)
* Remove destructor from GCEvent and instead rely on the OS to clean up
* Add a comment justifying the lack of destructor
* wording: many -> all
-rw-r--r-- | src/gc/env/gcenv.os.h | 11 | ||||
-rw-r--r-- | src/gc/unix/events.cpp | 6 | ||||
-rw-r--r-- | src/gc/windows/gcenv.windows.cpp | 6 | ||||
-rw-r--r-- | src/vm/gcenv.os.cpp | 6 |
4 files changed, 8 insertions, 21 deletions
diff --git a/src/gc/env/gcenv.os.h b/src/gc/env/gcenv.os.h index 6ea35e3142..d3e40ac4ff 100644 --- a/src/gc/env/gcenv.os.h +++ b/src/gc/env/gcenv.os.h @@ -50,6 +50,14 @@ struct GCThreadAffinity // An event is a synchronization object whose state can be set and reset // indicating that an event has occured. It is used pervasively throughout // the GC. +// +// Note that GCEvent deliberately leaks its contents by not having a non-trivial destructor. +// This is by design; since all uses of GCEvent have static lifetime, their destructors +// are run on process exit, potentially concurrently with other threads that may still be +// operating on the static event. To avoid these sorts of unsafety, GCEvent chooses to +// not have a destructor at all. The cost of this is leaking a small amount of memory, but +// this is not a problem since a majority of the uses of GCEvent are static. See CoreCLR#11111 +// for more details on the hazards of static destructors. class GCEvent { private: class Impl; @@ -59,9 +67,6 @@ public: // Constructs a new uninitialized event. GCEvent(); - // Destructs an event. - ~GCEvent(); - // Closes the event. Attempting to use the event past calling CloseEvent // is a logic error. void CloseEvent(); diff --git a/src/gc/unix/events.cpp b/src/gc/unix/events.cpp index f51eae80c3..7c665f4aaa 100644 --- a/src/gc/unix/events.cpp +++ b/src/gc/unix/events.cpp @@ -247,12 +247,6 @@ GCEvent::GCEvent() { } -GCEvent::~GCEvent() -{ - delete m_impl; - m_impl = nullptr; -} - void GCEvent::CloseEvent() { assert(m_impl != nullptr); diff --git a/src/gc/windows/gcenv.windows.cpp b/src/gc/windows/gcenv.windows.cpp index 0f3fd710e3..3749f06a68 100644 --- a/src/gc/windows/gcenv.windows.cpp +++ b/src/gc/windows/gcenv.windows.cpp @@ -690,12 +690,6 @@ GCEvent::GCEvent() { } -GCEvent::~GCEvent() -{ - delete m_impl; - m_impl = nullptr; -} - void GCEvent::CloseEvent() { assert(m_impl != nullptr); diff --git a/src/vm/gcenv.os.cpp b/src/vm/gcenv.os.cpp index 5e820a6169..77be88c96d 100644 --- a/src/vm/gcenv.os.cpp +++ b/src/vm/gcenv.os.cpp @@ -793,12 +793,6 @@ GCEvent::GCEvent() { } -GCEvent::~GCEvent() -{ - delete m_impl; - m_impl = nullptr; -} - void GCEvent::CloseEvent() { WRAPPER_NO_CONTRACT; |