Close and Dispose - which to call?

后端 未结 7 1037
慢半拍i
慢半拍i 2020-11-22 09:38

Having read the threads Is SqlCommand.Dispose enough? and Closing and Disposing a WCF Service I am wondering for classes such as SqlConnection or one of the several classes

相关标签:
7条回答
  • 2020-11-22 10:07

    I want to clarify this situation.

    According to Microsoft guidelines, it's a good practice to provide Close method where suitable. Here is a citation from Framework design guidelines

    Consider providing method Close(), in addition to the Dispose(), if close is standard terminology in the area. When doing so, it is important that you make the Close implementation identical to Dispose ...

    In most of cases Close and Dispose methods are equivalent. The main difference between Close and Dispose in the case of SqlConnectionObject is:

    An application can call Close more than one time. No exception is generated.

    If you called Dispose method SqlConnection object state will be reset. If you try to call any method on disposed SqlConnection object, you will receive exception.

    That said:

    • If you use connection object one time, use Dispose.
    • If connection object must be reused, use Close method.
    0 讨论(0)
提交回复
热议问题