AddLinkEntry Class 是原始类型。对泛型 AddLinkEntry Class<T> 的引用应该被参数化
AddLinkEntry Class is a raw type. References to generic type AddLinkEntry Class<T> should be parameterized
我有以下行抛出 "AddLinkEntry is a raw type. References to generic type AddLinkEntry should be parameterized" 警告
List<AddLinkEntry> addLinkCache = new ArrayList<AddLinkEntry>();
还有 AddLinkEntry class
public class AddLinkEntry<T> {
/**
* Function that Adds a link between this object and given object
*/
private IAddLinkToObjectFunctional<T> objectFunctional;
/**
* ID of given object
*/
private Id id;
/**
* Constructs a new {AddLinkEntry<T>}.
*
* @param objectFunctional
* Function that Adds a link between this object and given object
* @param id
* ID of given object
*/
public AddLinkEntry(IAddLinkToObjectFunctional<T> objectFunctional, Id id) {
this.objectFunctional = objectFunctional;
this.id = id;
}
/**
* Retrieve a function that Adds a link between this object and given object
*/
public IAddLinkToObjectFunctional<T> executeLinkage() {
return objectFunctional;
}
/**
* Retrieve an Id
*/
public Id getId() {
return id;
}
@FunctionalInterface
public interface IAddLinkToObjectFunctional<T> {
/**
* Adds a link between this object and given object
*
* @param objectNode a given object to link
*/
void addLink(T objectNode);
}
}
我想知道是什么原因导致警告以及如何在不使用抑制警告的情况下摆脱它?
我认为您还需要 AddLinkEntry
使用要存储的类型进行参数化
List<AddLinkEntry<String>> addLinkCache = new ArrayList<AddLinkEntry<String>>();
正如 Eran 所指出的那样,警告是由于直接使用原始类型 "AddLinkEntry" 引起的,作为 class 泛型本身,您应该提供更具体的类型,例如 Integer、String 等,其实例你想通过 java 保留在列表中进行静态类型检查,否则你只是邀请 "Classcastexception".
所以,List<AddLinkEntry<SpecificType>>
可以正常工作。
有关警告的详细信息,因为它可能不会简单 javac ,
使用标志-Xlint:rawtypes
我有以下行抛出 "AddLinkEntry is a raw type. References to generic type AddLinkEntry should be parameterized" 警告
List<AddLinkEntry> addLinkCache = new ArrayList<AddLinkEntry>();
还有 AddLinkEntry class
public class AddLinkEntry<T> {
/**
* Function that Adds a link between this object and given object
*/
private IAddLinkToObjectFunctional<T> objectFunctional;
/**
* ID of given object
*/
private Id id;
/**
* Constructs a new {AddLinkEntry<T>}.
*
* @param objectFunctional
* Function that Adds a link between this object and given object
* @param id
* ID of given object
*/
public AddLinkEntry(IAddLinkToObjectFunctional<T> objectFunctional, Id id) {
this.objectFunctional = objectFunctional;
this.id = id;
}
/**
* Retrieve a function that Adds a link between this object and given object
*/
public IAddLinkToObjectFunctional<T> executeLinkage() {
return objectFunctional;
}
/**
* Retrieve an Id
*/
public Id getId() {
return id;
}
@FunctionalInterface
public interface IAddLinkToObjectFunctional<T> {
/**
* Adds a link between this object and given object
*
* @param objectNode a given object to link
*/
void addLink(T objectNode);
}
}
我想知道是什么原因导致警告以及如何在不使用抑制警告的情况下摆脱它?
我认为您还需要 AddLinkEntry
使用要存储的类型进行参数化
List<AddLinkEntry<String>> addLinkCache = new ArrayList<AddLinkEntry<String>>();
正如 Eran 所指出的那样,警告是由于直接使用原始类型 "AddLinkEntry" 引起的,作为 class 泛型本身,您应该提供更具体的类型,例如 Integer、String 等,其实例你想通过 java 保留在列表中进行静态类型检查,否则你只是邀请 "Classcastexception".
所以,List<AddLinkEntry<SpecificType>>
可以正常工作。
有关警告的详细信息,因为它可能不会简单 javac ,
使用标志-Xlint:rawtypes