简而言之,它看起来像这样:
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.这将使它更清洁.
总结以上是内存溢出为你收集整理的c# – 我们可以用Java中的泛型做些什么来使它们看起来更好:全部内容,希望文章能够帮你解决c# – 我们可以用Java中的泛型做些什么来使它们看起来更好:所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)