类型参数命名准则是什么?
我注意到,并且在 Essential C# 3.0 书中看到,参数是通常定义为 T 或 TEntity
例如:
public class Stack<T>
{
}
或
public class EntityCollection<TEntity>
{
}
如何决定使用哪个名称?
谢谢
I noticed, as well as saw in the Essential C# 3.0 book, that paramters are usually defined as T or TEntity
For example:
public class Stack<T>
{
}
or
public class EntityCollection<TEntity>
{
}
How do you decide which name to use?
Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
我从 http://referencesource.microsoft.com/dotnet46.zip。 提取它并处理数据以从所有泛型类声明中提取泛型参数名称。
注意:我只从只有一个泛型参数的泛型类中提取了泛型参数名称。 因此,这没有考虑具有多个泛型参数的泛型类。
结果:
I fetched the .NET Framework 4.6 source code from http://referencesource.microsoft.com/dotnet46.zip. Extracted it and processed the data to extract the generic parameter name from all generic class declarations.
Note: I only extracted the generic parameter name from generic classes with only one generic parameter. So this does not take into consideration the generic classes with multiple generic parameters.
Result:
这是我的一套规则
半官方意见,值得一看关于该主题的框架设计指南:
Here is my set of rules
For a semi-official opinion, it's worth looking at the framework design guidelines on the subject:
最后,这并不重要。 使用有意义的命名约定。
可能不如
(或 TKey、TValue,如果您愿意的话)有用。
如果我正在查看您的实现并且必须思考“好吧,这个‘T3’又是什么?” 那你就没有做好。
In the end, it doesn't REALLY matter. Use a naming convention that makes sense.
is probably not as useful as
(or TKey, TValue, if you prefer).
If I'm looking at your implementation and have to think "ok, what is this 'T3' thing again?" then you didn't do a good job.
到目前为止,我已经查看了所有答案,我认为它们都部分正确,但没有充分考虑所有情况。
我的观点是命名应该始终增加上下文价值。 因此,命名类型参数
TEntity
因为其类型约束是IEntity
不一定会增加值,特别是因为 IntelliSense 无论如何都会指示其类型。 名称应反映类型参数的功能角色。 但这并不是说如果没有其他合适的描述性名称(并且单个字母不能不言自明),就不应该这样做。对于 one 类型参数,上下文通常在类方面应该是明显的,因此
T
就可以了。 对于多个类型参数,请为每个参数添加描述性上下文,例如TKey
和TValue
- 这是在多个类型参数为同一类型的情况下不应使用这些类型的另一个原因 (导致TEntity1
和TEntity2
几乎没有增加任何价值)?所以,我的答案与 JaredPar 和 Tomas Aschan 的答案类似,但有附加条件。
更新 2019 年 4 月 12 日:Microsoft 关于类型参数命名的指南 对于命名约定非常明确。 因此,我修改了我的答案以反映这一点,并删除了我说可以使用
T
、U
等或T1、
T2
等。根据指南,仅在存在单个类型参数(如果不言自明)的情况下才应使用单个字母。 始终对多个类型参数使用描述性名称。I've looked at all the answers so far, and I think they're all partially right, but don't fully consider all situations.
My view is that naming should always add contextual value. So, naming a type parameter
TEntity
because its type constraint isIEntity
would not necessarily add value, especially as IntelliSense would indicate its type anyway. The name should reflect the type parameter's functional role. But this is not to say it shouldn't be done if no other descriptive name is appropriate (and a single letter wouldn't be self-explanatory).In the case of one type parameter, the context should normally be obvious in terms of the class, so
T
is fine. For multiple type parameters, add a descriptive context to each such asTKey
andTValue
- another reason the types shouldn't be used in case multiple type parameters are the same type (resulting inTEntity1
andTEntity2
which adds little value)?So, my answer is similar to JaredPar and Tomas Aschan's answers, but with added qualification.
UPDATE 04/12/19: The Microsoft guidelines on type parameter naming are quite clear on the naming conventions. I've therefore modified my answer to reflect this, and removed the paragraph where I said it is acceptable to use
T
,U
, etc. orT1
,T2
, etc. From the guidelines, single letters should only be used where there is a single type parameter (if self-explanatory). Always use descriptive names for multiple type parameters.我认为您应该考虑以下几点:
一般来说,我总是在类型参数前加上
T
前缀,并使它们“具有足够的描述性”,这意味着它们需要具有描述性,以便我理解它们的作用和/或需要什么当我在六个月内查看代码时,他们。几个例子,在我看来,类型参数的良好命名(此列表中的编号与上面的编号无关......):
一个参数,从类名中可以明显看出(或者从代码中的上下文中得知)为什么需要类型名称:
由于我们可以看到这是一个
T
类型的对象列表,并且对T
没有具体的约束,因此不需要给出更具体的类型参数的名称。几个参数,代表通用类/接口中的不同事物:
我们需要能够区分两个参数,因此我们不提供值的键类型,反之亦然。 因此,将参数命名为
Key
和Value
,并以T
为前缀,似乎是合适的。我必须强调,这是比例如
IDictionary
或IDictionary
更好的做法,因为在后两种情况下没有直观地知道哪个参数将用于什么的方法。一个类型参数,但该类型必须满足某些要求或其他要求:
由于我们要求该类型实现另一个接口,因此向程序员提示这种情况是有意义的。 选择一些信息丰富的名称,帮助您了解类型的要求,并在其前面加上
T
前缀。There are a couple of things I think you should take into account:
In general, I always prefix my type arguments with
T
, and make them "descriptive enough", meaning as descriptive as they need to be for me to understand what they do, and/or what is required of them, when I look at the code in six months.A couple of examples of, in my opinion, good naming of type arguments (numbering in this list independent of numbering above...):
One argument, and it's obvious from the class name (or otherwise from the context in the code) why the type name is needed:
Since we can see that this is a list of objects of type
T
, and there are no specific constraints onT
, there is no need to give a more specific name to the type argument.Several arguments, that represent different things in the generic class/interface:
We need to be able to distinguish between the two arguments, so we don't supply the key type for value and vice versa. Thus, naming the arguments
Key
andValue
, and prefixing withT
, seems appropriate.I must emphasize that this is a much better practice than for example
IDictionary<T1, T2>
orIDictionary<T, U>
, since in the latter two cases there is no way to intuitively know which argument will be used for what.One type argument, but the type must fulfill some requirements or other:
Since we require that the type implements another interface, it makes sense to give some heads-up to the programmer that this is the case. Choose some informative name that helps you see what is required of the type, and prefix it with
T
.我真的不知道有任何可靠的泛型约定。
我见过的示例使用了其中一种 ff 变体:
T
表示单一类型参数,K
表示第二个类型参数,U
表示第二个类型参数。第三个,例如SomeGeneric
T
以及第二个和第三个类型参数的数字,例如SomeGeneric;
我猜仿制药还很新,通用的行业惯例还没有建立。
I'm not aware of any solid conventions for generics really.
The samples that I have seen though use one of the ff variations:
T
for single type parametersK
for a second type parameter,U
for a third, e.g.,SomeGeneric<T, K, U>
T
and a number for a second and third type parameter, e.g.,SomeGeneric<T1, T2, T3>
I guess generics are new enough that common industry conventions haven't been established yet.
来自微软的例子:
类型参数代表某物,所以如果你想要有可读的代码,这个“某物”应该从代码中显而易见(没有额外的注释)。 使用 T、V、U 等类型名称不一定很明显(但有时可能很明显)。
Example from Microsoft:
The type parameter represents something, so if you want to have readable code, this "something" should be obvious from the code (without extra comments). Using type names like T, V, U isn't necessarily obvious (but sometimes it can be).