-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Close() should NEVER call Dispose() #111258
Comments
Tagging subscribers to this area: @dotnet/area-system-componentmodel |
They are usually alias, for example
This is also implementation detail of the disposable pattern.
Re-opening is usually not a thing. Reusable objects must be specially designed other than non-reusable ones. For really-reusable objects like
Ideally it should, but it's impractical to really get exception-free when operating with external resource. The common practice is to not let it run, by calling
Any IO operation like network can get exception from physical connection lost, and not properly handling the exception will crash application. How is it related to |
I have to disagree. SerialPort is Component you can put onto a Form, then assign a port, Open, Close, assign different port, Open, Close, ...reuse. Why not?
No Close or Dispose ever helped with SerialPort in .NET 2.0 upto .NET 4.0 (at least 3.5) when you unplugged the USB (with VCP), because it threw exception from finalizer in GC-thread, which crashed the app, no matter what you did. EDIT:
See no such thing in
|
The runtime/src/libraries/System.IO.Ports/src/System/IO/Ports/SerialStream.Windows.cs Lines 724 to 734 in 289aa17
Decompiling the implementation of .NET Framework 2.0, it only guards for In contrast, runtime/src/libraries/System.Private.CoreLib/src/System/IO/Strategies/BufferedFileStreamStrategy.cs Lines 128 to 132 in 289aa17
It's not fatal. The finalizer of All of the problems come from the implementation of |
My apologies, but that is not an argument, it is nonsense. (Make Close trully Close the port and not Dispose the object, problem solved. How can you blame anybody for thinking that Close is Close and not Dispose?) But if you really want to convince me: Create simple Terminal app in WinForms using designer according to available documentation and suggestions. Document it and I will accept that I live in the past (.NET 2.0/3.5). Convince me, I beg you. Test it with CH340 and cheap replacements. I will accept the failure anyway, if you can proove it is "per design" and "working as expected", I will accept it.
Bla, bla, bla. It (SerialPort or its internal SerialStream) threw exception in GC-thread. FACT. My solution: I repurposed and fixed your Back to original: why should Close be Dispose? EDIT: there is a reason for this to even exist (not my code) |
It's the convention to do closing in
There are cases when types provided by the framework are unsuggested in favor of third party component, for example I do not have a time machine to answer or change things from the past. |
Changing existing semantics around Close-related methods and Dispose would be a large breaking change and would likely not be approved. The examples given are for code that is 20+ years old. If there is a specific issue regarding certain types, such finalizers with |
Bad convention and I think we actually agree on this.
Any proof anybody does that?
I almost expected that answer, did try anyway, execuse me for wasting your time, please.
There currently is a problem in SerialPort with CH340 and there are known issues and planned changes... will see about that.
That is most probably the reason why .NET 2.0/3.5 version crashed when you unplugged USB. NOTE: I always Anyway, I accept the close (of this issue). Have a nice day :) |
I apologyze for not knowing how to properly adress this thing, please forward where appropriate.
Close()
should NEVER callDispose()
Dispose()
orDispose(bool)
CAN callClose()
but NEVER the other way around!These (C/D) are two entirely different things, be it file or COM port or anything, especially when it is derived from
Component
.runtime/src/libraries/System.IO.Ports/src/System/IO/Ports/SerialPort.cs
Line 588 in 289aa17
There is bigger story about this, but the main logic is:
Close
should notDispose
, becauseDispose
can (and often does) more things likeGC.SuppressFinalize
runtime/src/libraries/System.ComponentModel.Primitives/src/System/ComponentModel/Component.cs
Line 74 in 289aa17
How are you supposed to re-
Open
it? That should work, right?....and
~Finalize()
should never throw an exception, right?Reality about SerialPort at least until .NET 4.5 when you unplug the USB - the whole App crashes and there was no defence.
At lest that got solved I hope:
runtime/src/libraries/System.IO.Ports/src/System/IO/Ports/SerialPort.cs
Line 593 in 289aa17
But wait, this gets called from
Close
as well, right?runtime/src/libraries/System.ComponentModel.Primitives/src/System/ComponentModel/Component.cs
Line 86 in 289aa17
runtime/src/libraries/System.ComponentModel.Primitives/src/System/ComponentModel/Component.cs
Line 89 in 289aa17
The text was updated successfully, but these errors were encountered: