Why does C# define two different uses for `using`?
More a question out of curiosity than anything, but why does C# define two different "purposes" for the keyword using
? On one hand, it's a directive...
used to create an alias for a namespace or to import types defined in other namespaces.
On the other, it's a statement which...
defines a scope, outside of which an object or objects will be disposed.
To me, it seems like different uses for the same keywor开发者_开发百科d, but maybe I'm missing something. Is there a reason why this keyword takes on two different purposes? Or, are both of these purposes, deep down in the belly of the compiler, really the same thing?
I asked Eric Lippert the same question on his blog a few years ago here (see the first comment).
His response was:
This is a tricky point of language design; when one keyword is used to represent two completely different concepts, it can be confusing. But introducing a new keyword per concept makes the language feel a bit bloated. I personally would have chosen "imports" or some such syntax for the directive form to ensure that it is not confused with the statement form, but I understand that its a judgment call.
We were designing a feature for C# 4.0 that got cut which was yet another form of "partial" class; basically, a way to share attribute metadata between the machine-generated and user-generated halves of a partial class. I pushed back on using the keyword "partial" for the feature because we would then have had THREE subtly different meanings for "partial" in C#, which I felt was two too many. (I was advocating adding another conditional keyword "existing". Unfortunately the point ended up moot since the feature was cut for lack of time.) -- Eric
For those who don't know who Eric is, he's a developer for the C# compiler team.
I cannot see how these two uses could be the same thing in the compiler.
I think the reason for the double use is simply the fact that the keyword fits very well for both of the purposes and there is no danger of ambiguity (one is directive, the other is statement, so they appear in completely different context). I think this is perfectly fine - a language should have a small number of keywords and their uses should be easy to understand - that's the case for both uses of using
.
As Linkgorn mentioned in a comment, another example of the same situation is where
which also exists in two places (generic constraints and LINQ query syntax).
First is that they do both fit the word, and since they both can't be used in the same context, they can't be confused for one another.
The reason, apart from any wording preferences, would be the number of language keywords.
Keywords are seperate from any library classes and such. I can create a method called DateTime without breaking or overlapping with the DateTime type, since I can just use namespaces to specify which one I want. But you cannot* create a method or variable called "public" because it is a language keyword.
Because of this most languages seek to keep the number of keywords to a minimum (some even boast how few keywords are used). Every word of the English language that is used as a keyword becomes unavailable to a programmer for other uses. When possible it's better to reuse existing keywords, rather then permanently remove another page from the programmers dictionary (especially if the language is already used, in which case a new keyword will break any code that used it as an identifier)
精彩评论