Skip to content

Commit

Permalink
Additional use and development comments for MemoryMappedInfo
Browse files Browse the repository at this point in the history
  • Loading branch information
sharwell committed May 16, 2017
1 parent 73aad3f commit 4a09b95
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,9 @@ internal partial class TemporaryStorageServiceFactory
/// <para><see cref="CriticalHandle"/> types are not reference counted, and are thus somewhat limited in their
/// usefulness. However, this handle class has tightly restricted accessibility and is only used by managed
/// code which does not rely on it counting references.</para>
///
/// <para>This is a supporting class for <see cref="MemoryMappedInfo"/>. See additional comments on that
/// class.</para>
/// </remarks>
private unsafe sealed class CopiedMemoryMappedViewHandle : CriticalHandleZeroOrMinusOneIsInvalid
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,19 @@ internal partial class TemporaryStorageServiceFactory
/// most of our view will have short lifetime, but there are cases where view might live a bit longer such as
/// metadata dll shadow copy. shared view will help those cases.
/// </summary>
/// <remarks>
/// <para>Instances of this class should be disposed when they are no longer needed. After disposing this
/// instance, it should no longer be used. However, streams obtained through <see cref="CreateReadableStream"/>
/// or <see cref="CreateWritableStream"/> will not be invalidated until they are disposed independently (which
/// may occur before or after the <see cref="MemoryMappedInfo"/> is disposed.</para>
///
/// <para>This class and its nested types have familiar APIs and predictable behavior when used in other code,
/// but are non-trivial to work on. The implementations of <see cref="IDisposable"/> adhere to the best
/// practices described in
/// <see href="http://joeduffyblog.com/2005/04/08/dg-update-dispose-finalization-and-resource-management/">DG
/// Update: Dispose, Finalization, and Resource Management</see>. Additional notes regarding operating system
/// behavior leveraged for efficiency are given in comments.</para>
/// </remarks>
internal sealed class MemoryMappedInfo : IDisposable
{
private readonly string _name;
Expand Down

0 comments on commit 4a09b95

Please sign in to comment.