java – 在异常的参数中使用泛型

前端之家收集整理的这篇文章主要介绍了java – 在异常的参数中使用泛型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试在异常中存储一些通用对象的集合,并且有麻烦弄清楚泛型.具体来说,我正在使用Hibernate Validator,并希望将收集到的违规列表保存在异常中,以便在另一层应用程序中进行处理.以下是一个例子:
  1. Set<ConstraintViolation<User>> violations = validator.validate(user);
  2. if (violations.size() > 0) {
  3. throw new ValidationException("User details are invalid",violations);
  4. }

在Eclipse中,throws行显示构造函数未定义,并建议我将构造函数签名更改为ValidationException(String,Set&ConstraintViolation< User>>>这里是ValidationException:

  1. public class ValidationException extends Exception {
  2. private Set<ConstraintViolation<?>> violations;
  3.  
  4. public ValidationException() {
  5. }
  6. public ValidationException(String msg) {
  7. super(msg);
  8. }
  9. public ValidationException(String msg,Throwable cause) {
  10. super(msg,cause);
  11. }
  12. public ValidationException(String msg,Set<ConstraintViolation<?>> violations) {
  13. super(msg);
  14. this.violations = violations;
  15. }
  16. public Set<ConstraintViolation<?>> getViolations() {
  17. return violations;
  18. }
  19. }

但是,我想保留ValidationException通用,以便我可以使用它不仅仅是用户验证.我试过Set< ConstraintViolation<? extends Object>>而且得到相同的结果.

有没有办法完成我想要做的事情?

解决方法

您需要将违规设置参数声明为Set<?扩展ConstraintViolation<?&gt ;::::
  1. public ValidationException(String msg,Set<? extends ConstraintViolation<?>> violations) {
  2. super(msg);
  3. this.violations = Collections.unmodifiableSet(
  4. new HashSet<ConstraintViolation<?>>(violations));
  5. }

那么一切都应该按预期工作.

这具有防御性复制所给予的Set的另外的好处,确保异常的内部集合不能被更改.

猜你在找的Java相关文章