Skip to content

Conversation

@stephentoub
Copy link
Member

Follow-up to #49852 (comment)

Method Mean Allocated
CreateMain 28.281 ns 184 B
CreatePR 4.504 ns 40 B
CreateAndValueMain 90.796 ns 376 B
CreateAndValuePR 69.512 ns 256 B

cc: @davidfowl, @eerhardt

@ghost
Copy link

ghost commented Mar 19, 2021

Tagging subscribers to this area: @maryamariyan
See info in area-owners.md if you want to be subscribed.

Issue Details

Follow-up to #49852 (comment)

Method Mean Allocated
CreateMain 28.281 ns 184 B
CreatePR 4.504 ns 40 B
CreateAndValueMain 90.796 ns 376 B
CreateAndValuePR 69.512 ns 256 B

cc: @davidfowl, @eerhardt

Author: stephentoub
Assignees: -
Labels:

area-Extensions-Options

Milestone: -

Copy link
Member

@eerhardt eerhardt left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

:shipit:

}

public TOptions Value => _lazy.Value;
lock (_syncObj ?? Interlocked.CompareExchange(ref _syncObj, new object(), null) ?? _syncObj)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was trying to write this pattern earlier. Very cool 😃

@davidfowl davidfowl merged commit fee6a7b into dotnet:main Mar 19, 2021
@stephentoub stephentoub deleted the reviseunnamedoptions branch March 19, 2021 19:59
@stephentoub stephentoub added the tenet-performance Performance related issue label Mar 19, 2021
@ghost ghost locked as resolved and limited conversation to collaborators Apr 18, 2021
@karelz karelz added this to the 6.0.0 milestone May 20, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants