Skip to content

Conversation

@pakrym
Copy link

@pakrym pakrym commented Nov 28, 2018

Before this change only items inside IEnumerable services were cached but not the arrays themselves.

Before:

    Method |        Mode |        Mean |      Error |     StdDev |         Op/s |    Gen 0 | Allocated |
---------- |------------ |------------:|-----------:|-----------:|-------------:|---------:|----------:|
 Transient |     Dynamic |   130.08 ns |  1.9756 ns |  1.8480 ns |  7,687,870.4 |  78.1250 |   16.4 MB |
    Scoped |     Dynamic |   368.52 ns |  3.8814 ns |  3.2412 ns |  2,713,550.4 |        - |   4.96 MB |
 Singleton |     Dynamic |    91.74 ns |  0.4798 ns |  0.4488 ns | 10,900,236.7 |  23.4375 |   4.96 MB |
 Transient | Expressions |   126.98 ns |  0.5482 ns |  0.4280 ns |  7,875,461.9 |  78.1250 |   16.4 MB |
    Scoped | Expressions |   370.26 ns |  4.7635 ns |  3.9777 ns |  2,700,821.2 |        - |   4.96 MB |
 Singleton | Expressions |   771.69 ns |  6.7945 ns |  6.0231 ns |  1,295,860.0 |        - |   4.96 MB |
 Transient |      ILEmit |   128.30 ns |  3.3772 ns |  3.1590 ns |  7,793,932.7 |  78.1250 |   16.4 MB |
    Scoped |      ILEmit |   360.98 ns |  6.1067 ns |  5.7122 ns |  2,770,274.2 |        - |   4.96 MB |
 Singleton |      ILEmit |   742.02 ns |  6.9257 ns |  6.4783 ns |  1,347,672.1 |        - |   4.96 MB |
 Transient |     Runtime | 6,602.27 ns | 97.5553 ns | 81.4631 ns |    151,463.1 | 500.0000 | 100.33 MB |
    Scoped |     Runtime | 1,076.62 ns |  7.2792 ns |  5.2633 ns |    928,830.7 |        - |   4.96 MB |
 Singleton |     Runtime | 1,039.67 ns |  4.8091 ns |  4.2631 ns |    961,840.9 |        - |   4.96 MB |

After:

    Method |        Mode |        Mean |      Error |     StdDev |         Op/s |    Gen 0 |   Allocated |
---------- |------------ |------------:|-----------:|-----------:|-------------:|---------:|------------:|
 Transient |     Dynamic |   127.30 ns |  2.5201 ns |  2.4751 ns |  7,855,466.6 |  78.1250 |  17200000 B |
    Scoped |     Dynamic |    93.48 ns |  1.0289 ns |  0.9624 ns | 10,697,556.7 |        - |         0 B |
 Singleton |     Dynamic |    47.40 ns |  0.3928 ns |  0.3482 ns | 21,098,399.1 |        - |         0 B |
 Transient | Expressions |   131.14 ns |  0.8885 ns |  0.7876 ns |  7,625,504.5 |  78.1250 |  17200000 B |
    Scoped | Expressions |    95.35 ns |  0.9309 ns |  0.8708 ns | 10,487,389.7 |        - |         0 B |
 Singleton | Expressions |   121.26 ns |  0.4251 ns |  0.3550 ns |  8,246,987.5 |        - |         0 B |
 Transient |      ILEmit |   130.85 ns |  2.4997 ns |  2.4551 ns |  7,642,496.9 |  78.1250 |  17200000 B |
    Scoped |      ILEmit |   111.34 ns |  2.0843 ns |  1.8477 ns |  8,981,606.0 |        - |         0 B |
 Singleton |      ILEmit |   119.04 ns |  1.6809 ns |  1.5723 ns |  8,400,255.4 |        - |         0 B |
 Transient |     Runtime | 6,600.38 ns | 94.7213 ns | 83.9680 ns |    151,506.4 | 437.5000 | 105200000 B |
    Scoped |     Runtime |   121.81 ns |  2.3620 ns |  2.2094 ns |  8,209,234.8 |        - |         0 B |
 Singleton |     Runtime |   116.17 ns |  1.8472 ns |  1.7278 ns |  8,608,186.3 |        - |         0 B |

@pakrym pakrym requested review from davidfowl and halter73 November 28, 2018 17:07
@pakrym pakrym force-pushed the pakrym/cache-ienum branch from 8394332 to 0e33e3a Compare November 28, 2018 18:04
@pakrym pakrym merged commit c89a5b5 into master Nov 29, 2018
@natemcmaster natemcmaster deleted the pakrym/cache-ienum branch December 4, 2018 19:56
maryamariyan pushed a commit to maryamariyan/runtime that referenced this pull request Feb 28, 2020
maryamariyan pushed a commit to maryamariyan/runtime that referenced this pull request Mar 2, 2020
maryamariyan pushed a commit to maryamariyan/runtime that referenced this pull request Mar 11, 2020
maryamariyan pushed a commit to maryamariyan/runtime that referenced this pull request Mar 27, 2020
maryamariyan pushed a commit to maryamariyan/performance that referenced this pull request Apr 3, 2020
adamsitnik added a commit to dotnet/performance that referenced this pull request Jun 23, 2020
* Reorganize source code

In preparation for merging many other projects into this repo, this establishes a new source code organization which groups projects together based on subject matter.


Commit migrated from dotnet/extensions@7ce647c

* Merge branch 'release/2.1' into release/2.2


Commit migrated from dotnet/extensions@18fcffb

* Merge branch 'release/2.2'


Commit migrated from dotnet/extensions@34204b6

* Reorganize source code in preparation to move into aspnet/Extensions

Prior to reorganization, this source code was found in https://github.com/aspnet/DependencyInjection/tree/7a283947c231b6585c8ac95e653950b660f3da96


Commit migrated from dotnet/extensions@689c4a8

* Reorganize source code in preparation to move into aspnet/Extensions

Prior to reorganization, this source code was found in https://github.com/aspnet/DependencyInjection/tree/12eef5e86e965b9611221c72c169002e6f3038ee


Commit migrated from dotnet/extensions@04e957b

* Reorganize source code in preparation to move into aspnet/Extensions

Prior to reorganization, this source code was found in https://github.com/aspnet/DependencyInjection/tree/d77b090567a1e6ad9a5bb5fd05f4bdcf281d4185


Commit migrated from dotnet/extensions@9a4c61b

* Reorganize source code in preparation to move into aspnet/Extensions

Prior to reorganization, this source code was found in https://github.com/aspnet/Logging/tree/f7d8e4e0537eaab54dcf28c2b148b82688a3d62d


Commit migrated from dotnet/extensions@f3cd14a

* Reorganize source code in preparation to move into aspnet/Extensions

Prior to reorganization, this source code was found in https://github.com/aspnet/HttpClientFactory/tree/cf7cf83ee869ed50a41852f5e880d073386b7fe7


Commit migrated from dotnet/extensions@c38f9c1

* Use the SharedSourceRoot variable in project files


Commit migrated from dotnet/extensions@888bcba

* Allow caching of IEnumerable services (dotnet/extensions#575)



Commit migrated from dotnet/extensions@c89a5b5

* Reduce event source logger allocations (dotnet/extensions#870)



Commit migrated from dotnet/extensions@091ee13

* Use Arcade (dotnet/extensions#586)

Use arcade


Commit migrated from dotnet/extensions@f045899

* Cleanup conversion to Arcade (dotnet/extensions#1014)

* Remove obsolete targets, properties, and scripts
* Replace IsProductComponent with IsShipping
* Undo bad merge to version.props
* Update documentation, and put workarounds into a common file
* Replace usages of RepositoryRoot with RepoRoot
* Remove API baselines
* Remove unnecessary restore feeds and split workarounds into two files
* Enable PR checks on all branches, and disable autocancel


Commit migrated from dotnet/extensions@f41cfde

* Shrink StringValues (dotnet/extensions#1283)



Commit migrated from dotnet/extensions@2f8e1fb

* Disable transitive project references in test projects (dotnet/extensions#1834)



Commit migrated from dotnet/extensions@e7d5bea

* Fix HTTP client benchmarks


Commit migrated from dotnet/extensions@8f0f7fa

* Add typed client creation benchmark


Commit migrated from dotnet/extensions@20ce03a

* Support netcoreapp3.1 TFM (dotnet/extensions#2336)

* Support netcoreapp3.1 TFM

* Unpin SDK for source build

* Update to preview1 branding


Commit migrated from dotnet/extensions@32cc816

* Normalize all file headers to the expected Apache 2.0 license


Commit migrated from dotnet/extensions@cec6e75

* Switch file headers to the MIT license


Commit migrated from dotnet/extensions@321a30c

* Moves Microsoft.Extensions.* perf tests over

* Using the Open key to fully sign assembly

- Needed to later get InternalsVisibleTo on DI

* Apply suggestions from code review

Make batch commit using suggestions in PR feedback

Co-authored-by: Adam Sitnik <[email protected]>

* Fix compile + other feedback

* Apply suggestions from code review

Co-authored-by: Nate McMaster <[email protected]>
Co-authored-by: Pavel Krymets <[email protected]>
Co-authored-by: Ryan Brandenburg <[email protected]>
Co-authored-by: Nate McMaster <[email protected]>
Co-authored-by: Ben Adams <[email protected]>
Co-authored-by: Ryan Nowak <[email protected]>
Co-authored-by: John Luo <[email protected]>
Co-authored-by: Sam Harwell <[email protected]>
Co-authored-by: Adam Sitnik <[email protected]>
@ghost ghost locked as resolved and limited conversation to collaborators May 29, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants