用于投射的Java外卡BestPractices
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了用于投射的Java外卡BestPractices,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1361字,纯文字阅读大概需要2分钟。
内容图文
![用于投射的Java外卡BestPractices](/upload/InfoBanner/zyjiaocheng/778/ae6898759b304fb09e51a7abdad12c76.jpg)
我已经对此进行了广泛的研究,似乎找不到这种情况的最佳实践.
ArrayList<GenericObject<?>> list = new ArrayList<>();
list.add( new GenericObject<Integer>(6) ); // Autoboxing
list.add( new GenericObject<String>("HI") );
if(list.get( 0 ).getGenaricValue().getClass() == Integer.class){
GenericObject<Integer> gi = (GenericObject<Integer>) list.get( 0 );
System.out.println("Was Integer");
System.out.println(gi);
}
}
虽然这段代码适用于GenericObject<?>的演员表.到GenericObject< Integer>给出一个未经检查的警告.现在您可以看到我已经使用我的if语句清楚地检查了类型,所以我对异常没有偏执,但有没有更好的方法来做到这一点而不必抑制未经检查的警告?这种情况有最佳实践吗?
我已经阅读了整个Generics oracle教程 here ,我已经阅读了很多stackoverflow帖子,但似乎都没有回答这个问题.任何帮助将不胜感激.
解决方法:
不,没有比抑制警告更好的方法,并作出解释:
@SuppressWarnings("unchecked") // this is okay because [insert reasoning]
GenericObject<Integer> gi = (GenericObject<Integer>) list.get( 0 );
请注意,这不一定是一个好的设计 – 如果可能的话,最好避免未经检查的强制转换,只是因为它们很难证明是合理的.例如,如果之前已将gi键入为GenericObject< Object>,该怎么办?或GenericObject< Number>刚刚碰巧持有一个整数?检查并转换值本身可能更好:
GenericObject<?> go = list.get(0);
Object obj = go.getGenericValue();
if (obj instanceof Integer) { // or obj.getClass() == Integer.class
System.out.println("Was Integer");
}
内容总结
以上是互联网集市为您收集整理的用于投射的Java外卡BestPractices全部内容,希望文章能够帮你解决用于投射的Java外卡BestPractices所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。