Not calling Dispose on HttpRequestMessage and HttpResponseMessage in asp.net core

后端 未结 1 1968
终归单人心
终归单人心 2021-01-01 18:03

What is the best practice for calling Dispose (or not) on HttpRequestMessage and HttpResponseMessage with asp.net core?

Examples:

https://github.com/aspnet/S

相关标签:
1条回答
  • 2021-01-01 18:24

    I opened an issue on the github repository where the code examples belong to.

    https://github.com/aspnet/Security/issues/886

    It's not important in these scenarios. Disposing a request or response only calls Dispose on their Content field. Of the various HttpContent implementations, only StreamContent needs to dispose anything. HttpClient's default SendAsync fully buffers the response content and disposes the stream, so there's nothing the caller needs to do.

    But for the sake of not getting weird bugs down the line, we are better off disposing those object. MemoryStream is another class that is also often not dispose because of his current underlying implementation.

    https://stackoverflow.com/a/234257/6524718

    If you're absolutely sure that you never want to move from a MemoryStream to another kind of stream, it's not going to do you any harm to not call Dispose. However, it's generally good practice partly because if you ever do change to use a different Stream, you don't want to get bitten by a hard-to-find bug because you chose the easy way out early on. (On the other hand, there's the YAGNI argument...)

    The other reason to do it anyway is that a new implementation may introduce resources which would be freed on Dispose.

    0 讨论(0)
提交回复
热议问题