我无法理解下面两个代码片段之间的区别.有人可以帮我解释一下吗?
首先,我必须说我有很多类扩展了一个名为的超类BaseEntity
,那么以下片段的区别,优点和缺点是什么?
// 1 publicT getName(T t) { return t; } // 2 public BaseEntity getName(BaseEntity t) { return t; }
Tagir Valeev.. 24
第一个片段更灵活,因为它保留了实际类型T
.假设你有一个子类:
class SubEntity extends BaseEntity {}
在第一种情况下,你可以写:
SubEntity result = getName(new SubEntity());
但在第二种情况下,你需要一个演员:
SubEntity result = (SubEntity)getName(new SubEntity());
hotzst.. 7
使用这两种方法时的主要区别是在第二种情况下可能需要铸造.
假设你有:
public class MyEntity extends BaseEntity { }
使用第一种方法,您可以使用以下内容:
MyEntity myEntity = ... MyEntity entity = getName(myEntity);
使用第二种方法时,您必须编写:
MyEntity entity = (MyEntity)getName(myEntity);
这是因为您在第一个方法中指定了具体类型.
第一个片段更灵活,因为它保留了实际类型T
.假设你有一个子类:
class SubEntity extends BaseEntity {}
在第一种情况下,你可以写:
SubEntity result = getName(new SubEntity());
但在第二种情况下,你需要一个演员:
SubEntity result = (SubEntity)getName(new SubEntity());
使用这两种方法时的主要区别是在第二种情况下可能需要铸造.
假设你有:
public class MyEntity extends BaseEntity { }
使用第一种方法,您可以使用以下内容:
MyEntity myEntity = ... MyEntity entity = getName(myEntity);
使用第二种方法时,您必须编写:
MyEntity entity = (MyEntity)getName(myEntity);
这是因为您在第一个方法中指定了具体类型.