我有这个方法使用列表元素的一个属性将List转换为Map:
简而言之,它看起来像这样:
private Map<String,List<Diagnostic<? extends JavaFileObject>>> toMap( List<Diagnostic<? extends JavaFileObject>> diagnostics ) { Map<String,List<Diagnostic<? extends JavaFileObject>>> result = new HashMap<String,List<Diagnostic<? extends JavaFileObject>>>(); for ( Diagnostic<? extends JavaFileObject> d : diagnostics ) { List<Diagnostic<? extends JavaFileObject>> list = null; if ( !result.containsKey( d.getCode() ) ) { list = new ArrayList<Diagnostic<? extends JavaFileObject>>(); result.put( d.getCode(),list ); } else { list = result.get( d.getCode() ); } assert list != null; list.add( d ); } return result; }
Yiack!..
我非常喜欢genercis,我之前使用java并且我不想回到演员阵容的所有时代,但是当一个泛型包含作为元素的通用元素时,它会变得混乱.
我知道在Java1.7中我们将能够使用“菱形”运算符,但应该有另一种方法.
这是非通用版本的样子:
private Map toMap( List diagnostics ) { Map result = new HashMap(); for( Object o : diagnostics ) { Diagnostic d = ( Diagnostic ) o; List list = null; if( !result.containsKey( d.getCode() ) ) { list = new ArrayList(); result.put( d.getCode(),list ); } else { list = result.get( d.getCode() ); } assert list != null; list.add( d ); } return result; }
大概,我没有尝试编译它.
其他语言如何处理?例如C#,Scala?我喜欢SML或Haskell处理的方式,但我认为太多魔法可能会受到伤害(但这当然是主观的)
这有解决方法吗?
解决方法
您定义了一个名为T的类型参数.然后您可以在通用中使用T,如下所示:
private <T extends JavaFileObject> Map<String,List<Diagnostic<T>> toMap(List<Diagnostic<T> diagnostics) { Map<String,List<Diagnostic<T>> result = new HashMap<String,List<Diagnostic<T>>(); for (Diagnostic<T> d : diagnostics ) { List<Diagnostic<T>> list = null; if ( !result.containsKey(d.getCode())) { list = new ArrayList<Diagnostic<T>>(); result.put( d.getCode(),list ); } else { list = result.get( d.getCode() ); } assert list != null; list.add( d ); } return result; }
上面你将看到定义为< T extends JavaFileObject>的类型参数.并且您可以在任何需要的地方重复使用T.这将使它更清洁.
原文地址:https://www.jb51.cc/csharp/97372.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。