immutable-collections
全部标签 我正在从丑陋的嵌套for循环转变为java中设计精美的lambda表达式。这是我的实际代码for(Stringfoo:foos){for(Barbar:bars){if(bar.getFoo().equals(foo)){FooBarfooBar=newFooBar();fooBar.setBar(bar);listOfFooBar.add(fooBar);break;}}}我实际的lambda代码来替换上面的代码foos.forEach(i->bars.stream().filter(p->p.getFoo().equals(i)).findFirst().ifPresent(p->
如果你有一个Liststrings例如,你会继续写:Collections.unmodifiableList(strings)或切换到:List.of(strings.toArray(newString[strings.size()]))实例化对性能(内存和运行时方面)的初始影响是什么?List.of中是否有运行时优势?变体? 最佳答案 这并不是一个很好的比较,因为这些方法做了不同的事情:Collections::unmodifiable...创建一个不可修改的View。它不是是不可变的,因为如果您更改原始的支持集合(您的示例中的l
Java字符串是不可变的,用相同的值实例化多个字符串返回相同的对象指针。(对此有一个术语吗?“池化”似乎很合适,但这已经指的是进行缓存以通过减少实例化来节省时间。)Java是否也对其他不可变的(用户定义的)类执行此操作(没有术语)?Java甚至可以检测到一个类是不可变的,或者这是字符串类所独有的东西? 最佳答案 写信。字符串,你要找的词是interning.Java不会为您自己的不可变对象(immutable对象)执行此操作。不过,它确实有盒装原语的缓存版本。请参阅wrapperclasscaching上的这篇文章了解更多信息。
我正在hibernate中创建一个CompositeUserType以将EAST和NORTH字段映射到坐标对象。目前,我的Coordinate对象是不可变的,如果可能的话,我希望保持这种状态。我已经编写了我的nullSafeGet,从ResultSet中提取坐标并调用构造函数:@OverridepublicObjectnullSafeGet(ResultSetrs,String[]names,SessionImplementorsession,Objectowner)throwsHibernateException,SQLException{Integereasting=(Intege
这个问题在这里已经有了答案:CheckingifacollectionisemptyinJava:whichisthebestmethod?(13个答案)Whyislist.size()>0slowerthanlist.isEmpty()inJava?(9个回答)关闭8年前。我已经阅读了很多关于isEmpty()和size()之间的区别的文章>0用于检查collection是否为空或不,发现isEmpty()的性能优于size()但我无法轻易理解为什么isEmpty()的性能很好,即使isEmpty()里面只有size==0吗?我的问题是:任何人都可以轻松解释在哪种情况下isEmpty
我有一些用Java编写的使用泛型的代码。这是一个简单的版本://InJavapublicinterfaceTestable{voidtest();}publicclassTestableImplimplementsTestable{@Overridepublicvoidtest(){System.out.println("hello");}}publicclassTest{publicvoidrunTest(Collectionts){System.out.println("Collection");for(Tt:ts)t.test();}publicvoidrunTest(Objec
在java.util.stream.Stream接口(interface)中,Rcollect(Suppliersupplier,BiConsumeraccumulator,BiConsumercombiner);组合器是一个BiConsumer,而在Rcollect(Collectorcollector);组合器是一个BinaryOperator这不过是一个BiFunction.虽然后一种形式清楚地定义了组合后组合对象的引用,但前一种形式没有。那么任何Stream实现库如何知道前一种情况下的组合对象是什么? 最佳答案 在Java9
一位同事提到他听说过一个轻量级集合,当内容太满时会自动分页到磁盘-但他记不起名字了。我想它看起来像这样:PagingCollectionpagingCollection=newPagingArrayList();pagingCollection.setMaxSizeInMemory(500);for(intx=0;x然后会将x=0到x=500推送到磁盘。关键是能够在不将整个内容加载到内存中的情况下对其进行迭代..这适用于内存量较少的胖客户端。有人知道它(或类似的东西)吗? 最佳答案 好吧,我所知道的唯一具有这种功能的工具是流行系统:
我可以collectalistofwordsintoabag(又名多集):Mapbag=Arrays.asList("oneo'clocktwoo'clockthreeo'clockrock".split("")).stream().collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));但是,不能保证袋子中的条目以任何特定顺序排列。例如,{rock=1,o'clock=3,one=1,three=1,two=1}我可以将它们放入列表中,然后使用我实现的值比较器对它们进行排序:ArrayList
当以下列方式将比较器应用于列表时,使用的是什么设计模式或这里使用的技术是什么?Collections.sort(myCollection,newComparator(){@Overridepublicintcompare(MyItemitem1,MyItemitem2){returnitem1.getId().compareTo(item2.getId());}}); 最佳答案 长话短说:Collections.sort是简单多态替换的示例,无论您是使用函数式编程还是面向对象编程来进行此替换.术语策略模式不能与多态性或函数式编程互换